日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql explain用法和结果的含义

發布時間:2024/2/28 数据库 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql explain用法和结果的含义 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉載自https://www.cnblogs.com/yycc/p/7338894.html

轉自:http://blog.chinaunix.net/uid-540802-id-3419311.html

?

explain顯示了mysql如何使用索引來處理select語句以及連接表。可以幫助選擇更好的索引和寫出更優化的查詢語句。

使用方法,在select語句前加上explain就可以了:

如:

  • explain?select?surname,first_name?form?a,b?where?a.id=b.id?
  • EXPLAIN列的解釋:

    table:顯示這一行的數據是關于哪張表的

    type:這是重要的列,顯示連接使用了何種類型。從最好到最差的連接類型為const、eq_reg、ref、range、index和ALL

    ? ? ? ? ?type顯示的是訪問類型,是較為重要的一個指標,結果值從好到壞依次是:system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL
    ? ? ? ? ?一般來說,得保證查詢至少達到range級別,最好能達到ref。

    possible_keys:顯示可能應用在這張表中的索引。如果為空,沒有可能的索引。可以為相關的域從WHERE語句中選擇一個合適的語句

    key: 實際使用的索引。如果為NULL,則沒有使用索引。很少的情況下,MYSQL會選擇優化不足的索引。這種情況下,可以在SELECT語句中使用USE INDEX(indexname)來強制使用一個索引或者用IGNORE INDEX(indexname)來強制MYSQL忽略索引

    key_len:使用的索引的長度。在不損失精確性的情況下,長度越短越好

    ref:顯示索引的哪一列被使用了,如果可能的話,是一個常數

    rows:MYSQL認為必須檢查的用來返回請求數據的行數

    Extra:關于MYSQL如何解析查詢的額外信息。將在表4.3中討論,但這里可以看到的壞的例子是Using temporary和Using filesort,意思MYSQL根本不能使用索引,結果是檢索會很慢

    extra列返回的描述的意義

    ?Distinct:一旦MYSQL找到了與行相聯合匹配的行,就不再搜索了

    ?Not exists: MYSQL優化了LEFT JOIN,一旦它找到了匹配LEFT JOIN標準的行,就不再搜索了

    ?Range checked for each Record(index map:#):沒有找到理想的索引,因此對于從前面表中來的每一個行組合,MYSQL檢查使用哪個索引,并用它來從表中返回行。這是使用索引的最慢的連接之一

    ?Using filesort: 看到這個的時候,查詢就需要優化了。MYSQL需要進行額外的步驟來發現如何對返回的行排序。它根據連接類型以及存儲排序鍵值和匹配條件的全部行的行指針來排序全部行

    ?Using index: 列數據是從僅僅使用了索引中的信息而沒有讀取實際的行動的表返回的,這發生在對表的全部的請求列都是同一個索引的部分的時候

    ?Using temporary 看到這個的時候,查詢需要優化了。這里,MYSQL需要創建一個臨時表來存儲結果,這通常發生在對不同的列集進行ORDER BY上,而不是GROUP BY上

    ?Where used 使用了WHERE從句來限制哪些行將與下一張表匹配或者是返回給用戶。如果不想返回表中的全部行,并且連接類型ALL或index,這就會發生,或者是查詢有問題不同連接類型的解釋(按照效率高低的順序排序)

    ?system 表只有一行:system表。這是const連接類型的特殊情況

    ?const:表中的一個記錄的最大值能夠匹配這個查詢(索引可以是主鍵或惟一索引)。因為只有一行,這個值實際就是常數,因為MYSQL先讀這個值然后把它當做常數來對待

    ?eq_ref:在連接中,MYSQL在查詢時,從前面的表中,對每一個記錄的聯合都從表中讀取一個記錄,它在查詢使用了索引為主鍵或惟一鍵的全部時使用

    ?ref:這個連接類型只有在查詢使用了不是惟一或主鍵的鍵或者是這些類型的部分(比如,利用最左邊前綴)時發生。對于之前的表的每一個行聯合,全部記錄都將從表中讀出。這個類型嚴重依賴于根據索引匹配的記錄多少—越少越好

    ?range:這個連接類型使用索引返回一個范圍中的行,比如使用>或<查找東西時發生的情況

    ?index: 這個連接類型對前面的表中的每一個記錄聯合進行完全掃描(比ALL更好,因為索引一般小于表數據)

    ?ALL:這個連接類型對于前面的每一個記錄聯合進行完全掃描,這一般比較糟糕,應該盡量避免

    ??

    先看一個例子:

  • mysql>?explain?select?*?from?t_order;?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+-------+?
  • |?id?|?select_type?|?table???|?type?|?possible_keys?|?key??|?key_len?|?ref??|?rows???|?Extra?|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+-------+?
  • |??1?|?SIMPLE??????|?t_order?|?ALL??|?NULL??????????|?NULL?|?NULL????|?NULL?|?100453?|???????|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+-------+?
  • 1?row?in?set?(0.03?sec)?
  • 加上extended后之后:

  • mysql>?explain?extended?select?*?from?t_order;?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+----------+-------+?
  • |?id?|?select_type?|?table???|?type?|?possible_keys?|?key??|?key_len?|?ref??|?rows???|?filtered?|?Extra?|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+----------+-------+?
  • |??1?|?SIMPLE??????|?t_order?|?ALL??|?NULL??????????|?NULL?|?NULL????|?NULL?|?100453?|???100.00?|???????|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+----------+-------+?
  • 1?row?in?set,?1?warning?(0.00?sec)?
  • 有必要解釋一下這個長長的表格里每一列的含義:

    idSELECT識別符。這是SELECT的查詢序列號
    select_type

    SELECT類型,可以為以下任何一種:

    • SIMPLE:簡單SELECT(不使用UNION或子查詢)
    • PRIMARY:最外面的SELECT
    • UNION:UNION中的第二個或后面的SELECT語句
    • DEPENDENT UNION:UNION中的第二個或后面的SELECT語句,取決于外面的查詢
    • UNION RESULT:UNION 的結果
    • SUBQUERY:子查詢中的第一個SELECT
    • DEPENDENT SUBQUERY:子查詢中的第一個SELECT,取決于外面的查詢
    • DERIVED:導出表的SELECT(FROM子句的子查詢)
    table

    輸出的行所引用的表

    type

    聯接類型。下面給出各種聯接類型,按照從最佳類型到最壞類型進行排序:

    • system:表僅有一行(=系統表)。這是const聯接類型的一個特例。
    • const:表最多有一個匹配行,它將在查詢開始時被讀取。因為僅有一行,在這行的列值可被優化器剩余部分認為是常數。const表很快,因為它們只讀取一次!
    • eq_ref:對于每個來自于前面的表的行組合,從該表中讀取一行。這可能是最好的聯接類型,除了const類型。
    • ref:對于每個來自于前面的表的行組合,所有有匹配索引值的行將從這張表中讀取。
    • ref_or_null:該聯接類型如同ref,但是添加了MySQL可以專門搜索包含NULL值的行。
    • index_merge:該聯接類型表示使用了索引合并優化方法。
    • unique_subquery:該類型替換了下面形式的IN子查詢的ref: value IN (SELECT primary_key FROM single_table WHERE some_expr) unique_subquery是一個索引查找函數,可以完全替換子查詢,效率更高。
    • index_subquery:該聯接類型類似于unique_subquery。可以替換IN子查詢,但只適合下列形式的子查詢中的非唯一索引: value IN (SELECT key_column FROM single_table WHERE some_expr)
    • range:只檢索給定范圍的行,使用一個索引來選擇行。
    • index:該聯接類型與ALL相同,除了只有索引樹被掃描。這通常比ALL快,因為索引文件通常比數據文件小。
    • ALL:對于每個來自于先前的表的行組合,進行完整的表掃描。
    possible_keys

    指出MySQL能使用哪個索引在該表中找到行

    key顯示MySQL實際決定使用的鍵(索引)。如果沒有選擇索引,鍵是NULL。
    key_len顯示MySQL決定使用的鍵長度。如果鍵是NULL,則長度為NULL。
    ref顯示使用哪個列或常數與key一起從表中選擇行。
    rows顯示MySQL認為它執行查詢時必須檢查的行數。多行之間的數據相乘可以估算要處理的行數。
    filtered顯示了通過條件過濾出的行數的百分比估計值。
    Extra

    該列包含MySQL解決查詢的詳細信息

    • Distinct:MySQL發現第1個匹配行后,停止為當前的行組合搜索更多的行。
    • Not exists:MySQL能夠對查詢進行LEFT JOIN優化,發現1個匹配LEFT JOIN標準的行后,不再為前面的的行組合在該表內檢查更多的行。
    • range checked for each record (index map: #):MySQL沒有發現好的可以使用的索引,但發現如果來自前面的表的列值已知,可能部分索引可以使用。
    • Using filesort:MySQL需要額外的一次傳遞,以找出如何按排序順序檢索行。
    • Using index:從只使用索引樹中的信息而不需要進一步搜索讀取實際的行來檢索表中的列信息。
    • Using temporary:為了解決查詢,MySQL需要創建一個臨時表來容納結果。
    • Using where:WHERE 子句用于限制哪一個行匹配下一個表或發送到客戶。
    • Using sort_union(...), Using union(...), Using intersect(...):這些函數說明如何為index_merge聯接類型合并索引掃描。
    • Using index for group-by:類似于訪問表的Using index方式,Using index for group-by表示MySQL發現了一個索引,可以用來查 詢GROUP BY或DISTINCT查詢的所有列,而不要額外搜索硬盤訪問實際的表。

    ?

    一.select_type的說明

    1.UNION:

    當通過union來連接多個查詢結果時,第二個之后的select其select_type為UNION。

  • mysql>?explain?select?*?from?t_order?where?order_id=100?union?select?*?from?t_order?where?order_id=200;?
  • +----+--------------+------------+-------+---------------+---------+---------+-------+------+-------+?
  • |?id?|?select_type??|?table??????|?type??|?possible_keys?|?key?????|?key_len?|?ref???|?rows?|?Extra?|?
  • +----+--------------+------------+-------+---------------+---------+---------+-------+------+-------+?
  • |??1?|?PRIMARY??????|?t_order????|?const?|?PRIMARY???????|?PRIMARY?|?4???????|?const?|????1?|???????|?
  • |??2?|?UNION????????|?t_order????|?const?|?PRIMARY???????|?PRIMARY?|?4???????|?const?|????1?|???????|?
  • |?NULL?|?UNION?RESULT?|?<union1,2>?|?ALL???|?NULL??????????|?NULL????|?NULL????|?NULL??|?NULL?|???????|?
  • +----+--------------+------------+-------+---------------+---------+---------+-------+------+-------+?
  • 3?rows?in?set?(0.34?sec)?
  • 2.DEPENDENT UNION與DEPENDENT SUBQUERY:

    當union作為子查詢時,其中第二個union的select_type就是DEPENDENT UNION。
    第一個子查詢的select_type則是DEPENDENT SUBQUERY。

  • mysql>?explain?select?*?from?t_order?where?order_id?in?(select?order_id?from?t_order?where?order_id=100?union?select?order_id?from?t_order?where?order_id=200);?
  • +----+--------------------+------------+-------+---------------+---------+---------+-------+--------+-------------+?
  • |?id?|?select_type????????|?table??????|?type??|?possible_keys?|?key?????|?key_len?|?ref???|?rows???|?Extra???????|?
  • +----+--------------------+------------+-------+---------------+---------+---------+-------+--------+-------------+?
  • |??1?|?PRIMARY????????????|?t_order????|?ALL???|?NULL??????????|?NULL????|?NULL????|?NULL??|?100453?|?Using?where?|?
  • |??2?|?DEPENDENT?SUBQUERY?|?t_order????|?const?|?PRIMARY???????|?PRIMARY?|?4???????|?const?|??????1?|?Using?index?|?
  • |??3?|?DEPENDENT?UNION????|?t_order????|?const?|?PRIMARY???????|?PRIMARY?|?4???????|?const?|??????1?|?Using?index?|?
  • |?NULL?|?UNION?RESULT???????|?<union2,3>?|?ALL???|?NULL??????????|?NULL????|?NULL????|?NULL??|???NULL?|?????????????|?
  • +----+--------------------+------------+-------+---------------+---------+---------+-------+--------+-------------+?
  • 4?rows?in?set?(0.03?sec)?
  • 3.SUBQUERY:

    子查詢中的第一個select其select_type為SUBQUERY。

  • mysql>?explain?select?*?from?t_order?where?order_id=(select?order_id?from?t_order?where?order_id=100);?
  • +----+-------------+---------+-------+---------------+---------+---------+-------+------+-------------+?
  • |?id?|?select_type?|?table???|?type??|?possible_keys?|?key?????|?key_len?|?ref???|?rows?|?Extra???????|?
  • +----+-------------+---------+-------+---------------+---------+---------+-------+------+-------------+?
  • |??1?|?PRIMARY?????|?t_order?|?const?|?PRIMARY???????|?PRIMARY?|?4???????|?const?|????1?|?????????????|?
  • |??2?|?SUBQUERY????|?t_order?|?const?|?PRIMARY???????|?PRIMARY?|?4???????|???????|????1?|?Using?index?|?
  • +----+-------------+---------+-------+---------------+---------+---------+-------+------+-------------+?
  • 2?rows?in?set?(0.03?sec)?
  • 4.DERIVED:

    當子查詢是from子句時,其select_type為DERIVED。

  • mysql>?explain?select?*?from?(select?order_id?from?t_order?where?order_id=100)?a;?
  • +----+-------------+------------+--------+---------------+---------+---------+------+------+-------------+?
  • |?id?|?select_type?|?table??????|?type???|?possible_keys?|?key?????|?key_len?|?ref??|?rows?|?Extra???????|?
  • +----+-------------+------------+--------+---------------+---------+---------+------+------+-------------+?
  • |??1?|?PRIMARY?????|?<derived2>?|?system?|?NULL??????????|?NULL????|?NULL????|?NULL?|????1?|?????????????|?
  • |??2?|?DERIVED?????|?t_order????|?const??|?PRIMARY???????|?PRIMARY?|?4???????|??????|????1?|?Using?index?|?
  • +----+-------------+------------+--------+---------------+---------+---------+------+------+-------------+?
  • 2?rows?in?set?(0.03?sec)?
  • 二.type的說明

    1.system,const

    見上面4.DERIVED的例子。其中第一行的type就是為system,第二行是const,這兩種聯接類型是最快的。

    2.eq_ref

    在t_order表中的order_id是主鍵,t_order_ext表中的order_id也是主鍵,該表可以認為是訂單表的補充信息表,他們的關系是1對1,在下面的例子中可以看到b表的連接類型是eq_ref,這是極快的聯接類型。

  • mysql>?explain?select?*?from?t_order?a,t_order_ext?b?where?a.order_id=b.order_id;?
  • +----+-------------+-------+--------+---------------+---------+---------+-----------------+------+-------------+?
  • |?id?|?select_type?|?table?|?type???|?possible_keys?|?key?????|?key_len?|?ref?????????????|?rows?|?Extra???????|?
  • +----+-------------+-------+--------+---------------+---------+---------+-----------------+------+-------------+?
  • |??1?|?SIMPLE??????|?b?????|?ALL????|?order_id??????|?NULL????|?NULL????|?NULL????????????|????1?|?????????????|?
  • |??1?|?SIMPLE??????|?a?????|?eq_ref?|?PRIMARY???????|?PRIMARY?|?4???????|?test.b.order_id?|????1?|?Using?where?|?
  • +----+-------------+-------+--------+---------------+---------+---------+-----------------+------+-------------+?
  • 2?rows?in?set?(0.00?sec)?
  • 3.ref

    下面的例子在上面的例子上略作了修改,加上了條件。此時b表的聯接類型變成了ref。因為所有與a表中order_id=100的匹配記錄都將會從b表獲取。這是比較常見的聯接類型。

  • mysql>?explain?select?*?from?t_order?a,t_order_ext?b?where?a.order_id=b.order_id?and?a.order_id=100;?
  • +----+-------------+-------+-------+---------------+----------+---------+-------+------+-------+?
  • |?id?|?select_type?|?table?|?type??|?possible_keys?|?key??????|?key_len?|?ref???|?rows?|?Extra?|?
  • +----+-------------+-------+-------+---------------+----------+---------+-------+------+-------+?
  • |??1?|?SIMPLE??????|?a?????|?const?|?PRIMARY???????|?PRIMARY??|?4???????|?const?|????1?|???????|?
  • |??1?|?SIMPLE??????|?b?????|?ref???|?order_id??????|?order_id?|?4???????|?const?|????1?|???????|?
  • +----+-------------+-------+-------+---------------+----------+---------+-------+------+-------+?
  • 2?rows?in?set?(0.00?sec)?
  • 4.ref_or_null

    user_id字段是一個可以為空的字段,并對該字段創建了一個索引。在下面的查詢中可以看到聯接類型為ref_or_null,這是mysql為含有null的字段專門做的處理。在我們的表設計中應當盡量避免索引字段為NULL,因為這會額外的耗費mysql的處理時間來做優化。

  • mysql>?explain?select?*?from?t_order?where?user_id=100?or?user_id?is?null;?
  • +----+-------------+---------+-------------+---------------+---------+---------+-------+-------+-------------+?
  • |?id?|?select_type?|?table???|?type????????|?possible_keys?|?key?????|?key_len?|?ref???|?rows??|?Extra???????|?
  • +----+-------------+---------+-------------+---------------+---------+---------+-------+-------+-------------+?
  • |??1?|?SIMPLE??????|?t_order?|?ref_or_null?|?user_id???????|?user_id?|?5???????|?const?|?50325?|?Using?where?|?
  • +----+-------------+---------+-------------+---------------+---------+---------+-------+-------+-------------+?
  • 1?row?in?set?(0.00?sec)?
  • 5.index_merge

    經常出現在使用一張表中的多個索引時。mysql會將多個索引合并在一起,如下例:

  • mysql>?explain?select?*?from?t_order?where?order_id=100?or?user_id=10;?
  • +----+-------------+---------+-------------+-----------------+-----------------+---------+------+------+-------------------------------------------+?
  • |?id?|?select_type?|?table???|?type????????|?possible_keys???|?key?????????????|?key_len?|?ref??|?rows?|?Extra?????????????????????????????????????|?
  • +----+-------------+---------+-------------+-----------------+-----------------+---------+------+------+-------------------------------------------+?
  • |??1?|?SIMPLE??????|?t_order?|?index_merge?|?PRIMARY,user_id?|?PRIMARY,user_id?|?4,5?????|?NULL?|????2?|?Using?union(PRIMARY,user_id);?Using?where?|?
  • +----+-------------+---------+-------------+-----------------+-----------------+---------+------+------+-------------------------------------------+?
  • 1?row?in?set?(0.09?sec)?
  • 6.unique_subquery

    該聯接類型用于替換value IN (SELECT primary_key FROM single_table WHERE some_expr)這樣的子查詢的ref。注意ref列,其中第二行顯示的是func,表明unique_subquery是一個函數,而不是一個普通的ref。

  • mysql>?explain?select?*?from?t_order?where?order_id?in?(select?order_id?from?t_order?where?user_id=10);?
  • +----+--------------------+---------+-----------------+-----------------+---------+---------+------+--------+-------------+?
  • |?id?|?select_type????????|?table???|?type????????????|?possible_keys???|?key?????|?key_len?|?ref??|?rows???|?Extra???????|?
  • +----+--------------------+---------+-----------------+-----------------+---------+---------+------+--------+-------------+?
  • |??1?|?PRIMARY????????????|?t_order?|?ALL?????????????|?NULL????????????|?NULL????|?NULL????|?NULL?|?100649?|?Using?where?|?
  • |??2?|?DEPENDENT?SUBQUERY?|?t_order?|?unique_subquery?|?PRIMARY,user_id?|?PRIMARY?|?4???????|?func?|??????1?|?Using?where?|?
  • +----+--------------------+---------+-----------------+-----------------+---------+---------+------+--------+-------------+?
  • 2?rows?in?set?(0.00?sec)?
  • 7.index_subquery

    該聯接類型與上面的太像了,唯一的差別就是子查詢查的不是主鍵而是非唯一索引。

  • mysql>?explain?select?*?from?t_order?where?user_id?in?(select?user_id?from?t_order?where?order_id>10);?
  • +----+--------------------+---------+----------------+-----------------+---------+---------+------+--------+--------------------------+?
  • |?id?|?select_type????????|?table???|?type???????????|?possible_keys???|?key?????|?key_len?|?ref??|?rows???|?Extra????????????????????|?
  • +----+--------------------+---------+----------------+-----------------+---------+---------+------+--------+--------------------------+?
  • |??1?|?PRIMARY????????????|?t_order?|?ALL????????????|?NULL????????????|?NULL????|?NULL????|?NULL?|?100649?|?Using?where??????????????|?
  • |??2?|?DEPENDENT?SUBQUERY?|?t_order?|?index_subquery?|?PRIMARY,user_id?|?user_id?|?5???????|?func?|??50324?|?Using?index;?Using?where?|?
  • +----+--------------------+---------+----------------+-----------------+---------+---------+------+--------+--------------------------+?
  • 2?rows?in?set?(0.00?sec)?
  • 8.range

    按指定的范圍進行檢索,很常見。

  • mysql>?explain?select?*?from?t_order?where?user_id?in?(100,200,300);?
  • +----+-------------+---------+-------+---------------+---------+---------+------+------+-------------+?
  • |?id?|?select_type?|?table???|?type??|?possible_keys?|?key?????|?key_len?|?ref??|?rows?|?Extra???????|?
  • +----+-------------+---------+-------+---------------+---------+---------+------+------+-------------+?
  • |??1?|?SIMPLE??????|?t_order?|?range?|?user_id???????|?user_id?|?5???????|?NULL?|????3?|?Using?where?|?
  • +----+-------------+---------+-------+---------------+---------+---------+------+------+-------------+?
  • 1?row?in?set?(0.00?sec)?
  • 9.index

    在進行統計時非常常見,此聯接類型實際上會掃描索引樹,僅比ALL快些。

  • mysql>?explain?select?count(*)?from?t_order;?
  • +----+-------------+---------+-------+---------------+---------+---------+------+--------+-------------+?
  • |?id?|?select_type?|?table???|?type??|?possible_keys?|?key?????|?key_len?|?ref??|?rows???|?Extra???????|?
  • +----+-------------+---------+-------+---------------+---------+---------+------+--------+-------------+?
  • |??1?|?SIMPLE??????|?t_order?|?index?|?NULL??????????|?user_id?|?5???????|?NULL?|?100649?|?Using?index?|?
  • +----+-------------+---------+-------+---------------+---------+---------+------+--------+-------------+?
  • 1?row?in?set?(0.00?sec)?
  • 10.ALL

    完整的掃描全表,最慢的聯接類型,盡可能的避免。

  • mysql>?explain?select?*?from?t_order;?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+-------+?
  • |?id?|?select_type?|?table???|?type?|?possible_keys?|?key??|?key_len?|?ref??|?rows???|?Extra?|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+-------+?
  • |??1?|?SIMPLE??????|?t_order?|?ALL??|?NULL??????????|?NULL?|?NULL????|?NULL?|?100649?|???????|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+-------+?
  • 1?row?in?set?(0.00?sec)?
  • 三.extra的說明

    1.Distinct

    MySQL發現第1個匹配行后,停止為當前的行組合搜索更多的行。對于此項沒有找到合適的例子,求指點。

    2.Not exists

    因為b表中的order_id是主鍵,不可能為NULL,所以mysql在用a表的order_id掃描t_order表,并查找b表的行時,如果在b表發現一個匹配的行就不再繼續掃描b了,因為b表中的order_id字段不可能為NULL。這樣避免了對b表的多次掃描。

  • mysql>?explain?select?count(1)?from?t_order?a?left?join?t_order_ext?b?on?a.order_id=b.order_id?where?b.order_id?is?null;??
  • +----+-------------+-------+-------+---------------+--------------+---------+-----------------+--------+--------------------------------------+?
  • |?id?|?select_type?|?table?|?type??|?possible_keys?|?key??????????|?key_len?|?ref?????????????|?rows???|?Extra????????????????????????????????|?
  • +----+-------------+-------+-------+---------------+--------------+---------+-----------------+--------+--------------------------------------+?
  • |??1?|?SIMPLE??????|?a?????|?index?|?NULL??????????|?express_type?|?1???????|?NULL????????????|?100395?|?Using?index??????????????????????????|?
  • |??1?|?SIMPLE??????|?b?????|?ref???|?order_id??????|?order_id?????|?4???????|?test.a.order_id?|??????1?|?Using?where;?Using?index;?Not?exists?|?
  • +----+-------------+-------+-------+---------------+--------------+---------+-----------------+--------+--------------------------------------+?
  • 2?rows?in?set?(0.01?sec)?
  • 3.Range checked for each record

    這種情況是mysql沒有發現好的索引可用,速度比沒有索引要快得多。

  • mysql>?explain?select?*?from?t_order?t,?t_order_ext?s?where?s.order_id>=t.order_id?and?s.order_id<=t.order_id?and?t.express_type>5;?
  • +----+-------------+-------+-------+----------------------+--------------+---------+------+------+------------------------------------------------+?
  • |?id?|?select_type?|?table?|?type??|?possible_keys????????|?key??????????|?key_len?|?ref??|?rows?|?Extra??????????????????????????????????????????|?
  • +----+-------------+-------+-------+----------------------+--------------+---------+------+------+------------------------------------------------+?
  • |??1?|?SIMPLE??????|?t?????|?range?|?PRIMARY,express_type?|?express_type?|?1???????|?NULL?|????1?|?Using?where????????????????????????????????????|?
  • |??1?|?SIMPLE??????|?s?????|?ALL???|?order_id?????????????|?NULL?????????|?NULL????|?NULL?|????1?|?Range?checked?for?each?record?(index?map:?0x1)?|?
  • +----+-------------+-------+-------+----------------------+--------------+---------+------+------+------------------------------------------------+?
  • 2?rows?in?set?(0.00?sec)
  • 4.Using filesort

    在有排序子句的情況下很常見的一種情況。此時mysql會根據聯接類型瀏覽所有符合條件的記錄,并保存排序關鍵字和行指針,然后排序關鍵字并按順序檢索行。

  • mysql>?explain?select?*?from?t_order?order?by?express_type;?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+----------------+?
  • |?id?|?select_type?|?table???|?type?|?possible_keys?|?key??|?key_len?|?ref??|?rows???|?Extra??????????|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+----------------+?
  • |??1?|?SIMPLE??????|?t_order?|?ALL??|?NULL??????????|?NULL?|?NULL????|?NULL?|?100395?|?Using?filesort?|?
  • +----+-------------+---------+------+---------------+------+---------+------+--------+----------------+?
  • 1?row?in?set?(0.00?sec)?
  • 5.Using index

    這是性能很高的一種情況。當查詢所需的數據可以直接從索引樹中檢索到時,就會出現。上面的例子中有很多這樣的例子,不再多舉例了。

    6.Using temporary

    發生這種情況一般都是需要進行優化的。mysql需要創建一張臨時表用來處理此類查詢。

  • mysql>?explain?select?*?from?t_order?a?left?join?t_order_ext?b?on?a.order_id=b.order_id?group?by?b.order_id;?
  • +----+-------------+-------+------+---------------+----------+---------+-----------------+--------+---------------------------------+?
  • |?id?|?select_type?|?table?|?type?|?possible_keys?|?key??????|?key_len?|?ref?????????????|?rows???|?Extra???????????????????????????|?
  • +----+-------------+-------+------+---------------+----------+---------+-----------------+--------+---------------------------------+?
  • |??1?|?SIMPLE??????|?a?????|?ALL??|?NULL??????????|?NULL?????|?NULL????|?NULL????????????|?100395?|?Using?temporary;?Using?filesort?|?
  • |??1?|?SIMPLE??????|?b?????|?ref??|?order_id??????|?order_id?|?4???????|?test.a.order_id?|??????1?|?????????????????????????????????|?
  • +----+-------------+-------+------+---------------+----------+---------+-----------------+--------+---------------------------------+?
  • 2?rows?in?set?(0.00?sec)?
  • 7.Using where

    當有where子句時,extra都會有說明。

    8.Using sort_union(...)/Using union(...)/Using intersect(...)

    下面的例子中user_id是一個檢索范圍,此時mysql會使用sort_union函數來進行索引的合并。而當user_id是一個固定值時,請參看上面type說明5.index_merge的例子,此時會使用union函數進行索引合并。

  • mysql>?explain?select?*?from?t_order?where?order_id=100?or?user_id>10;?
  • +----+-------------+---------+-------------+-----------------+-----------------+---------+------+------+------------------------------------------------+?
  • |?id?|?select_type?|?table???|?type????????|?possible_keys???|?key?????????????|?key_len?|?ref??|?rows?|?Extra??????????????????????????????????????????|?
  • +----+-------------+---------+-------------+-----------------+-----------------+---------+------+------+------------------------------------------------+?
  • |??1?|?SIMPLE??????|?t_order?|?index_merge?|?PRIMARY,user_id?|?user_id,PRIMARY?|?5,4?????|?NULL?|????2?|?Using?sort_union(user_id,PRIMARY);?Using?where?|?
  • +----+-------------+---------+-------------+-----------------+-----------------+---------+------+------+------------------------------------------------+?
  • 1?row?in?set?(0.00?sec)?
  • 對于Using intersect的例子可以參看下例,user_id與express_type發生了索引交叉合并。

  • mysql>?explain?select?*?from?t_order?where?express_type=1?and?user_id=100;?
  • +----+-------------+---------+-------------+----------------------+----------------------+---------+------+------+----------------------------------------------------+?
  • |?id?|?select_type?|?table???|?type????????|?possible_keys????????|?key??????????????????|?key_len?|?ref??|?rows?|?Extra??????????????????????????????????????????????|?
  • +----+-------------+---------+-------------+----------------------+----------------------+---------+------+------+----------------------------------------------------+?
  • |??1?|?SIMPLE??????|?t_order?|?index_merge?|?user_id,express_type?|?user_id,express_type?|?5,1?????|?NULL?|????1?|?Using?intersect(user_id,express_type);?Using?where?|?
  • +----+-------------+---------+-------------+----------------------+----------------------+---------+------+------+----------------------------------------------------+?
  • 1?row?in?set?(0.00?sec)?
  • 9.Using index for group-by

    表明可以在索引中找到分組所需的所有數據,不需要查詢實際的表。

  • mysql>?explain?select?user_id?from?t_order?group?by?user_id;?
  • +----+-------------+---------+-------+---------------+---------+---------+------+------+--------------------------+?
  • |?id?|?select_type?|?table???|?type??|?possible_keys?|?key?????|?key_len?|?ref??|?rows?|?Extra????????????????????|?
  • +----+-------------+---------+-------+---------------+---------+---------+------+------+--------------------------+?
  • |??1?|?SIMPLE??????|?t_order?|?range?|?NULL??????????|?user_id?|?5???????|?NULL?|????3?|?Using?index?for?group-by?|?
  • +----+-------------+---------+-------+---------------+---------+---------+------+------+--------------------------+?
  • 1?row?in?set?(0.00?sec)?
  • 除了上面的三個說明,還需要注意rows的數值,多行之間的數值是乘積的關系,可以估算大概要處理的行數,如果乘積很大,那就很有優化的必要了。

    總結

    以上是生活随笔為你收集整理的mysql explain用法和结果的含义的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    免费婷婷 | 欧美日韩另类在线 | 人人艹人人 | 国产精品久久一区二区三区, | 成人影视免费看 | 亚洲黄色大片 | 欧美 亚洲 另类 激情 另类 | 亚洲欧美色婷婷 | 伊人中文网| 一级片视频免费观看 | 亚洲日韩欧美视频 | 色网站免费在线看 | 免费观看xxxx9999片 | 精品99在线观看 | 天天操天天干天天操天天干 | 国产又粗又猛又色又黄视频 | 国产精在线 | 日韩理论片中文字幕 | 黄色激情网址 | 免费看v片网站 | 久久激情婷婷 | 在线看片成人 | 国产精品毛片久久久久久久 | 天天色综合1 | 国产一级特黄毛片在线毛片 | 在线国产一区 | 一区二区不卡视频在线观看 | 久草青青在线观看 | 久久久久草| 久草精品视频在线播放 | 探花视频在线观看 | 91精品国产综合久久久久久久 | 久久综合加勒比 | 久久精品视频在线观看免费 | av丝袜在线 | 激情视频91| 亚洲国产网站 | 国产久草在线观看 | 日本精品va在线观看 | 国产成人精品一区二区在线观看 | 色偷偷88888欧美精品久久 | 在线直播av | 中文在线www | 亚洲欧美综合精品久久成人 | 久久96| 久久久国产99久久国产一 | 91久久国产综合精品女同国语 | 91中文字幕一区 | 日韩在线一级 | 色多多污污在线观看 | 久久久久亚洲国产 | 我爱av激情网 | 日韩欧美在线免费观看 | 综合激情网 | www.午夜色.com | 成人日批视频 | 亚州日韩中文字幕 | 中国一级片在线播放 | 激情中文在线 | 毛片激情永久免费 | 日本三级在线观看中文字 | 国产女人18毛片水真多18精品 | 五月天激情视频在线观看 | 国产成人免费高清 | 久久久久久久久久久久亚洲 | 天天干天天摸 | 一级黄网 | 久久精品日产第一区二区三区乱码 | 日韩动漫免费观看高清完整版在线观看 | 久久成人麻豆午夜电影 | 国产精品igao视频网入口 | 五月开心六月伊人色婷婷 | 久久激情五月婷婷 | 国产精品一码二码三码在线 | av电影中文字幕在线观看 | 久久国产精品99久久久久久进口 | 久久免费看毛片 | 成人影片在线播放 | 午夜av在线电影 | 一区二区三区视频网站 | 国产精品视频免费观看 | 欧美91成人网 | 国产一级电影 | 国产亚洲精品免费 | 久久精品免费看 | 亚洲午夜电影网 | 欧美精品被 | 久草视频免费观 | 99久久这里只有精品 | 免费日韩 | 1024手机看片国产 | 欧美最猛性xxxxx(亚洲精品) | 99热国产在线中文 | 欧美a性 | 亚洲四虎影院 | 月下香电影 | 亚洲国产精久久久久久久 | 91视频电影| 欧美日韩免费在线观看视频 | 免费久久精品视频 | 九色精品 | 久久av免费| 一区二区在线电影 | 国内小视频在线观看 | 国产最顶级的黄色片在线免费观看 | 亚洲人天堂| 欧美国产三区 | 午夜美女wwww | 久久精品这里精品 | 亚洲精品系列 | 97超碰人人澡人人爱 | 黄色av免费 | 韩日色视频 | 成人免费 在线播放 | 精品久久久久久一区二区里番 | 亚洲第一中文字幕 | 亚洲精品在线免费看 | 日韩在线免费播放 | 亚洲视频在线观看网站 | 九九久久国产精品 | 免费看一级黄色大全 | 中文字幕久久亚洲 | 日日草av| 中文字幕在线观看视频网站 | 国产精品一区二区美女视频免费看 | 久久一区二区三区国产精品 | 久久国产精品色婷婷 | 一区二区视频欧美 | 91pony九色丨交换 | 午夜精品视频免费在线观看 | 中文字幕在线网 | 久久综合中文字幕 | 高清av在线免费观看 | 丁香婷婷激情网 | 狠狠色丁香婷婷综合久久片 | 在线99| 成人a免费| 亚洲乱码国产乱码精品天美传媒 | 免费黄在线看 | 91黄视频在线观看 | 日韩色视频在线观看 | 91大神一区二区三区 | 欧美福利片在线观看 | 日韩激情一二三区 | 热久久最新地址 | 欧美一二区视频 | 欧美一区二区精美视频 | 日韩伦理片hd | 欧美极品久久 | 国产精品久久久免费 | 久久综合成人网 | 国产精品一区二区果冻传媒 | 欧美日韩国产色综合一二三四 | 中日韩免费视频 | 国产精品淫| 久久久久国产一区二区三区四区 | 国产一级电影在线 | 欧美日韩中文在线观看 | 99欧美视频 | 香蕉视频啪啪 | 黄www在线观看| 国产黄色高清 | 精品国产一区二区三区不卡 | 久久国产精品99久久久久 | 黄色特级毛片 | 国产 日韩 在线 亚洲 字幕 中文 | 精品欧美在线视频 | 五月综合色婷婷 | 91激情在线视频 | 日韩免费看视频 | 欧美精品第一 | 韩国av不卡 | 五月综合色婷婷 | 亚洲资源网 | 国产日韩视频在线 | 亚洲视频每日更新 | 国产精久久| 人人草人人做 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 成人久久免费视频 | 91在线看黄 | 欧美性生活大片 | 在线看黄色的网站 | 人人爱夜夜操 | 日韩有色| 99久久99视频只有精品 | 免费污片 | 日日摸日日添夜夜爽97 | 亚洲日日日 | 中文字幕文字幕一区二区 | 精品久久久久久久久久久久久久久久久久 | 亚洲经典在线 | 天天综合网~永久入口 | 99精品免费网 | 3d黄动漫免费看 | 日本精品视频在线播放 | 日本激情动作片免费看 | 香蕉在线影院 | 久久精品中文字幕一区二区三区 | 91在线资源 | 久久一区二区三区国产精品 | 99精品视频免费看 | 久草在线观看 | 一级a性色生活片久久毛片波多野 | 亚洲永久国产精品 | a视频免费 | 成人黄色在线观看视频 | 97涩涩视频| 人人澡人人干 | 国产精品一区二区久久精品爱微奶 | 久久99视频 | 久久精品视频99 | 免费91麻豆精品国产自产在线观看 | 成人久久亚洲 | 天天爽综合网 | 色婷婷av国产精品 | 人人操日日干 | 亚洲天天看 | 国产日韩精品在线 | 91九色网站 | 亚洲精品tv久久久久久久久久 | 成年人黄色免费视频 | 日韩中文字幕免费视频 | 天天操天天干天天爱 | 992tv在线成人免费观看 | 黄色av电影在线观看 | 国产精品剧情在线亚洲 | 国产免费午夜 | 欧美日韩视频一区二区 | 亚洲一区av | 五月天综合色激情 | av福利在线看 | 国产精品久久久777 成人手机在线视频 | 在线播放第一页 | 亚洲欧美日韩国产一区二区三区 | 新版资源中文在线观看 | 麻豆传媒视频在线免费观看 | 欧美日韩国产精品一区二区三区 | 一区二区三区在线免费 | 久久欧洲视频 | av不卡中文 | 国产一二三区在线观看 | 国产日韩精品一区二区 | 黄色com| 国产一二三四在线视频 | 99精品视频在线观看免费 | 久草视频在线看 | 欧美视频日韩视频 | 丁香六月天婷婷 | 国产一级片免费播放 | 色综合婷婷久久 | 色美女在线 | 国产99爱| 国产成人久久精品77777综合 | 日韩欧在线 | 精品久久久久久综合日本 | 亚洲四虎 | 97电影网手机版 | 国产精品美女久久久免费 | 亚洲精品观看 | 日日摸日日爽 | 精品久久久久久亚洲综合网站 | 国产一区免费在线观看 | 亚洲一区二区三区在线看 | 天天干天天爽 | 九九久久精品视频 | 午夜男人影院 | 丁香六月在线 | 亚洲一区久久久 | 亚洲国产精品电影 | 欧美污网站| 久久免费视频2 | 日韩网站免费观看 | 精品欧美日韩 | 福利一区二区三区四区 | 欧美日韩99 | 91av在线免费观看 | 久久免费精彩视频 | 午夜久久久精品 | 久久你懂的 | 六月丁香六月婷婷 | 在线影视 一区 二区 三区 | 欧美日韩三级在线观看 | 日韩伦理片hd | 国产高清在线免费 | 国产黄色视| 五月激情av | 国产麻豆精品传媒av国产下载 | 欧美va日韩va| 中文字幕a在线 | 亚洲黄色av网址 | 免费看污黄网站 | 久热免费 | 国产精品美女久久久久久网站 | 欧美做受69 | 五月天综合在线 | 中文字幕在线免费观看视频 | 91香蕉嫩草| 亚洲www天堂com | 人人爽人人爱 | 精品高清美女精品国产区 | 日韩在线第一 | 综合激情网 | 日韩精品91偷拍在线观看 | 97在线观看免费观看高清 | 一区二区精品在线 | 五月婷婷av | zzijzzij日本成熟少妇 | 中文字幕在线免费观看视频 | 欧美有色 | 久久国内精品 | 一个色综合网站 | 天天玩天天操天天射 | 天堂激情网| 日韩a在线 | av免费观看网站 | 国产69久久久| 欧美日韩久久一区 | 婷婷亚洲综合五月天小说 | 欧美成人精品三级在线观看播放 | 婷婷六月综合网 | 成人91免费视频 | 色的网站在线观看 | 在线免费日韩 | 久久爱992xxoo| 久久久亚洲麻豆日韩精品一区三区 | 91伊人影院 | 九色在线 | 亚洲狠狠操| 久久艹中文字幕 | 超碰97人人射妻 | 亚洲午夜久久久久久久久 | 国产精品久久久久久久久久 | 国产精品久久久久毛片大屁完整版 | 夜夜躁狠狠躁日日躁 | 久久免费av| 麻豆视频免费网站 | 国产精品免费大片视频 | 麻豆传媒视频观看 | 日韩,中文字幕 | 中文字幕av有码 | 亚洲欧洲日韩在线观看 | 国产精品扒开做爽爽的视频 | 91精品国自产在线 | 美女福利视频网 | 日韩电影久久久 | 97精品国产91久久久久久 | 一区二区三区不卡在线 | 人人舔人人干 | 狠狠躁日日躁狂躁夜夜躁 | 丁香五婷 | 中文字幕国产视频 | 久久精品2 | 男女免费视频观看 | 久久一级电影 | 天天干天天玩天天操 | 成人在线视频免费观看 | 久久av中文字幕片 | 亚洲精品视频在线观看免费视频 | 91精彩视频 | a级国产乱理伦片在线观看 亚洲3级 | 国产高清免费在线播放 | 中文字幕在线视频一区二区 | 久热久草| 奇米先锋 | 在线观看国产区 | 国产九色在线播放九色 | 91精品啪在线观看国产81旧版 | 国产 一区二区三区 在线 | av中文字幕在线播放 | 韩国三级在线一区 | 色综合激情久久 | 国产精品久久久久久五月尺 | 黄色av网站在线观看免费 | 一区在线观看 | 天天综合网 天天综合色 | 国产午夜精品一区二区三区嫩草 | 97日日碰人人模人人澡分享吧 | avcom在线 | 欧美色图狠狠干 | 欧美精品九九99久久 | 成人国产精品免费观看 | 亚洲爱视频 | 亚洲天堂网在线播放 | 久久a级片 | 久久久久久久久毛片 | 国产精品露脸在线 | 国产精品女同一区二区三区久久夜 | 日本中文不卡 | 国产成人精品网站 | 国产亚洲精品xxoo | 免费在线观看成人 | 国产91在线观 | 亚洲福利精品 | 亚洲精品乱码久久久久久蜜桃91 | 国产尤物在线观看 | 美女视频黄免费的 | 狠狠狠狠狠狠天天爱 | 久久精品欧美视频 | 日韩中文字幕a | 麻豆传媒在线免费看 | 婷婷久久久| 亚洲精品无 | 国产精品久久久久久久久久久久久 | 成人免费共享视频 | 51久久夜色精品国产麻豆 | 亚洲综合日韩在线 | 精品欧美日韩 | 久久久久久亚洲精品 | 丰满少妇在线观看 | 久久久精品影视 | 精精国产xxxx视频在线播放 | 精品久久国产 | 亚洲激情久久 | 国模视频一区二区三区 | 亚洲国产精品久久久 | 欧美日韩国产二区 | 亚洲精品国产精品国 | 亚洲国产99 | 日本中文字幕在线播放 | 久久亚洲福利 | 99精品在线看 | 少妇bbbb搡bbbb搡bbbb | 国产成人精品一区二区三区福利 | 视频高清 | 日日夜夜精品视频天天综合网 | 欧美日韩视频 | 午夜精品一区二区三区免费视频 | 色婷婷午夜| 久久久久久久18 | 久久99热久久99精品 | 亚洲伊人第一页 | 在线电影中文字幕 | 色视频网站在线观看一=区 a视频免费在线观看 | 激情文学综合丁香 | 高清精品在线 | 欧美日韩一区二区三区视频 | 免费成人在线观看视频 | 色播五月婷婷 | 天天插狠狠插 | 国产v在线播放 | 欧美另类sm图片 | 超碰免费在线公开 | 一区二区三区免费在线 | 欧美一级片免费观看 | 在线黄色国产电影 | 日韩在线免费不卡 | 久久99热国产 | 色婷婷福利| 久久久久久久久福利 | 久精品视频免费观看2 | 91亚洲精品国产 | 国产99久久久国产精品 | 91tv国产成人福利 | 天天爱天天草 | 日韩特黄一级欧美毛片特黄 | 91精品国产91久久久久 | 欧美疯狂性受xxxxx另类 | 天天综合亚洲 | 麻花天美星空视频 | 日韩精品在线免费观看 | 啪嗒啪嗒免费观看完整版 | 日韩午夜精品福利 | 97精品国产91久久久久久久 | 狠狠躁日日躁夜夜躁av | 久草精品视频 | 免费在线观看国产黄 | 伊人网综合在线观看 | 又黄又爽又色无遮挡免费 | 亚洲高清在线视频 | 麻豆视频网址 | 日韩高清免费在线观看 | 日韩二区三区在线 | 91麻豆精品久久久久久 | 免费人成网ww44kk44 | www夜夜操 | 天天色图 | 欧美日韩国产二区 | 成人黄色视| 国产精品午夜免费福利视频 | 91在线区 | 久久精品9 | 国产成人一区二区三区电影 | 久章草在线 | 日韩av视屏 | 狠狠狠色丁香综合久久天下网 | 国产精品男女 | 91综合视频在线观看 | 狠狠狠色丁香婷婷综合久久五月 | 正在播放亚洲精品 | 日韩欧美69 | 色综合久久88色综合天天6 | 日韩免费在线观看视频 | 日韩艹| 天天躁日日躁狠狠 | 成人午夜性影院 | 久久久激情网 | 三级黄色三级 | 国产精品精品国产婷婷这里av | 亚洲闷骚少妇在线观看网站 | 在线免费观看亚洲视频 | 美女在线免费视频 | 久久视频这里有久久精品视频11 | 国产精品资源在线观看 | 久久成人资源 | 99产精品成人啪免费网站 | 久久精品国产免费看久久精品 | www视频在线免费观看 | 国产精品视频永久免费播放 | 97超碰资源站 | 最新超碰在线 | 欧美一区二区三区特黄 | 国产高清视频在线免费观看 | 日本中文在线 | 亚洲v欧美v国产v在线观看 | 亚洲天堂精品视频在线观看 | 日韩免费二区 | 亚洲在线免费视频 | 欧美日韩免费在线视频 | 中文字幕在线看片 | 久久er99热精品一区二区 | 狠狠狠狠狠狠狠干 | 欧美精品亚州精品 | 亚洲精品乱码久久久久久蜜桃不爽 | 国产精品美女久久久久久久久久久 | 亚洲综合激情 | 91免费网| 97色在线观看免费视频 | 日韩女同一区二区三区在线观看 | 国产九色视频在线观看 | 欧美日韩在线看 | av免费看在线 | 中文字幕激情 | 免费午夜av | 欧美夫妻性生活电影 | 天天操天天舔天天爽 | 人人澡超碰碰97碰碰碰软件 | 亚洲视频在线观看 | 91亚洲在线观看 | 国产一级片观看 | 亚洲欧洲国产视频 | 日本巨乳在线 | 免费的国产精品 | 日韩av美女| 五月天激情婷婷 | 日本久久免费电影 | 涩涩网站在线观看 | www夜夜| 国产69精品久久久久99 | 中文字幕av免费 | 91在线视频免费 | 久久高清视频免费 | 黄色毛片视频 | 三上悠亚一区二区在线观看 | 国际精品网 | 久久私人影院 | 免费看国产视频 | 日韩理论片在线观看 | 成人一区二区在线观看 | 国内免费久久久久久久久久久 | 国产在线999| 婷婷新五月 | 国产一区二区三区视频在线 | 亚洲精品视频一二三 | 日本午夜在线观看 | 99国内精品 | 国产福利91精品一区二区三区 | 国产免费黄色 | 在线视频 你懂得 | 免费视频91蜜桃 | 国产小视频福利在线 | 国产在线一区二区 | 婷婷五天天在线视频 | 久久99热国产 | 在线天堂中文www视软件 | 中文字幕91 | 在线 国产 日韩 | 成人国产精品久久久 | 奇米影视8888在线观看大全免费 | 五月婷网站 | 久草线 | 国产精彩视频一区 | 久久国产精品视频观看 | 手机av观看 | 久久夜夜夜 | 欧美成人亚洲成人 | 国产一区二区三区视频在线 | 国产精品igao视频网入口 | 99成人免费视频 | 久久免费大片 | 久久精品99北条麻妃 | 国产成人精品女人久久久 | 黄色av电影免费观看 | 91av电影在线| 国产美女免费观看 | 久久手机在线视频 | 亚洲激精日韩激精欧美精品 | 在线观看黄网站 | 久久久久久久久黄色 | 黄色在线观看免费 | 国产精品久久久久永久免费 | 樱空桃av | 97超碰影视| 国产精品久久久久久电影 | av丝袜在线 | 亚洲精品黄色 | 在线观看黄色免费视频 | 久久一区二区三区超碰国产精品 | 麻豆视频在线 | 国产一区二区精品91 | 久久乐九色婷婷综合色狠狠182 | 日韩久久久久久久久 | 久久综合9988久久爱 | 免费成人在线网站 | 97人人超碰在线 | 99国产精品免费网站 | 日韩精品在线观看av | 最新av观看 | 精品一二三四五区 | 黄污网站在线观看 | 91秒拍国产福利一区 | 国产九九热视频 | 久久av黄色 | 日韩欧美一区二区三区免费观看 | 亚洲va欧美| 久久成人国产精品免费软件 | 精品国产成人在线 | 91精品在线免费视频 | 国产色婷婷 | 偷拍区另类综合在线 | 婷婷九九 | 久久夜色精品国产欧美乱极品 | 色婷婷免费视频 | 日韩一二三在线 | 中文字幕一区二区三区四区 | 久久婷婷激情 | 亚洲一区二区三区在线看 | 日本mv大片欧洲mv大片 | 99久久久久久 | 国内99视频 | 国产精品久久久久久久久久妇女 | www.色的 | 超碰在线人 | 丁香在线观看完整电影视频 | 一区二区三区免费播放 | 麻豆免费在线视频 | 久久99国产精品久久99 | 91精品一区二区三区蜜桃 | 在线免费黄网站 | 91中文字幕视频 | 黄色国产大片 | 久久久久高清 | 国产福利一区二区三区在线观看 | 亚洲国产97在线精品一区 | 国产在线免费 | 麻豆 free xxxx movies hd| 免费高清无人区完整版 | 欧美日韩高清一区二区 | 特级毛片网 | 91av在线免费观看 | av一级一片 | 99自拍视频在线观看 | 99精品视频中文字幕 | 黄色毛片大全 | 一级欧美日韩 | 天天激情站| 日韩精品一区在线播放 | 久久免费精彩视频 | 天天激情综合 | 亚洲香蕉在线观看 | 精品国产一区二区三区久久久 | 国产视频久久久 | 日本中文字幕在线观看 | av片在线观看免费 | 久久久国产视频 | 中文字幕av全部资源www中文字幕在线观看 | 午夜av色| 黄色网大全 | 国产午夜一区二区 | 麻豆国产在线播放 | 亚洲一区久久久 | 美女网站在线观看 | 最近最新mv字幕免费观看 | 黄色三级免费 | 亚洲国产精品500在线观看 | 国产一区视频在线 | 最新av网址在线观看 | 少妇bbb| 日p在线观看 | 日韩精品视频免费专区在线播放 | 国产精品久久婷婷六月丁香 | a天堂在线看 | 麻豆传媒电影在线观看 | 91九色在线| 欧美激情综合色综合啪啪五月 | 日韩成人免费在线 | 国产激情电影综合在线看 | 丁香婷五月 | 国产蜜臀av| 国产精品扒开做爽爽的视频 | 久草在线中文888 | 国产丝袜高跟 | 国产一级特黄电影 | 天天做天天爱天天综合网 | 国产中文字幕在线视频 | 亚洲欧美视频 | av网站大全免费 | 一区二区三区四区在线免费观看 | 国产成人精品一区一区一区 | 色偷偷网站视频 | 亚洲三级在线播放 | 久久综合久久综合这里只有精品 | 国产精品va在线 | 亚洲国产精品视频 | 久久久国产在线视频 | 国产精品一区二区免费视频 | 日韩网站在线免费观看 | 一区二区三区高清在线观看 | 欧美aaa一级 | 日韩在线观看视频一区二区三区 | 成年人免费电影 | 日本久久片 | 久久嗨 | 少妇性色午夜淫片aaaze | 一区二区三区日韩视频在线观看 | 亚洲精品国产精品国 | 99热最新地址 | www.久久久 | 韩国精品一区二区三区六区色诱 | 日韩高清免费在线 | 久久久国产精品视频 | 91网站免费观看 | 成人九九视频 | 黄色91在线| 色就干| 91亚洲免费| 国产精品嫩草影视久久久 | 香蕉在线视频观看 | 热久久国产精品 | 久久影院午夜论 | 免费看片成人 | 国产精品高潮呻吟久久久久 | av网站在线观看免费 | 日韩色av色资源 | 超碰免费久久 | 永久免费的av电影 | 中文字幕网址 | 深爱五月激情网 | 国产成人区 | 久久久国产精品久久久 | 成人免费视频网 | 天天干天天在线 | 特级片免费看 | 美女一二三区 | 天天射色综合 | 国产精品入口传媒 | 久久久夜色 | 日韩精品中文字幕在线观看 | 日韩在线不卡视频 | 国产91丝袜在线播放动漫 | 2019中文字幕网站 | 在线色视频小说 | 一级淫片a | 国产精彩在线视频 | 国产高清专区 | 成人网页在线免费观看 | 超碰精品在线观看 | 欧美人牲 | www夜夜| 免费观看91视频大全 | 亚洲最大的av网站 | 久草网视频在线观看 | 狠狠狠狠狠狠操 | 久av在线 | 五月综合在线观看 | www.综合网.com | 在线影院 国内精品 | 永久免费观看视频 | 婷婷av在线| 超碰在线人人艹 | 久久99精品久久久久久清纯直播 | 欧美日韩视频在线一区 | 久久久久高清毛片一级 | 亚洲一区欧美激情 | av免费电影网站 | 久艹在线免费观看 | 99草在线视频 | 日韩欧美高清 | 999久久国精品免费观看网站 | 日本中文字幕在线播放 | 免费高清无人区完整版 | 天天艹天天 | 91在线观看高清 | 亚洲精品乱码久久久久久 | 国产午夜免费视频 | 亚洲成av人影片在线观看 | 国产亚洲精品久久久久久 | 精品夜夜嗨av一区二区三区 | 免费看一级黄色大全 | 成人免费观看a | 日韩a免费 | 亚洲天天综合网 | 一区二区三区国产欧美 | 婷婷丁香狠狠爱 | 国产精品一区二区三区四区在线观看 | 久久久99国产精品免费 | 婷婷伊人综合亚洲综合网 | 国产精品一区二区三区在线 | 日韩超碰在线 | 狠狠色伊人亚洲综合网站野外 | 日韩视频免费在线 | 又黄又爽又色无遮挡免费 | 在线观看国产中文字幕 | 99久久久久国产精品免费 | 99久久精品国产亚洲 | 中文字幕中文字幕在线中文字幕三区 | 国产亚洲欧美一区 | 国产在线精品区 | 99久久精品日本一区二区免费 | 久久久精品一区二区 | 成人在线播放网站 | av一级一片 | 在线观看视频一区二区三区 | 伊人久久av | 色视频网站免费观看 | 国产成人99久久亚洲综合精品 | 国产丝袜高跟 | 日韩av中文字幕在线免费观看 | 色在线国产 | 国产精品美女网站 | 成人在线视频免费观看 | 日日干综合 | 超碰免费成人 | 日日操天天爽 | 久久免费看a级毛毛片 | 91福利社在线观看 | 免费看片网站91 | 视频一区视频二区在线观看 | 免费日韩一级片 | 日本精品久久久久中文字幕 | 久久99精品视频 | 久久99这里只有精品 | www.日本色 | 亚洲我射av | 97av影院 | 亚洲精品资源在线 | 欧美性一级观看 | av女优中文字幕在线观看 | 一本一本久久a久久精品综合小说 | 一级免费片| 97视频在线免费观看 | 成片免费观看视频 | 中文字幕在线观看免费高清电影 | 伊人五月婷 | 国产黄色一级片在线 | 超碰在线人人艹 | 91在线色| 国产123区在线观看 国产精品麻豆91 | 婷婷久久精品 | 日韩欧三级 | 欧美精品亚洲精品日韩精品 | 精品在线免费观看 | 狠狠狠色丁香婷婷综合激情 | 久久国产精品色婷婷 | 欧美一进一出抽搐大尺度视频 | 天天干夜夜夜 | 日韩欧美99 | 免费看污黄网站 | 99久久影院| 日本 在线 视频 中文 有码 | 亚洲理论电影 | 国产伦精品一区二区三区免费 | 天天草网站 | 爱爱av网 | 日韩在线视频在线观看 | 韩日精品在线 | 久久精品这里都是精品 | 国产一区欧美一区 | 在线网站黄 | 色资源在线 | 中文在线亚洲 | 亚洲美女视频在线 | 亚洲精品在线一区二区三区 | 日本精品久久久久久 | 五月天激情视频在线观看 | 成人毛片a | 综合网欧美 | 久久久久福利视频 | 91av九色 | 欧美少妇18p| 午夜精品一区二区三区在线观看 | 综合久久久久久久久 | 国产精品岛国久久久久久久久红粉 | 最新av网址在线观看 | 超碰97国产 | 日本三级中文字幕在线观看 | www.夜夜操.com | 97视频免费 | 99久久精品国产系列 | 日韩欧美视频一区二区 | 豆豆色资源网xfplay | 99色 | 中文字幕一区二区三区乱码不卡 | 四虎成人精品在永久免费 | 911国产在线观看 | 911久久香蕉国产线看观看 | 国产精品久久久久久久免费 | 97超碰中文 | 精品久久久久久国产偷窥 | 在线免费视频你懂的 | 久久国产精品二国产精品中国洋人 | 国产一级h | 99久久精品国产一区 | 黄色国产区| 国产探花视频在线播放 | 免费av电影网站 | 亚洲人毛片 | 五月天视频网 | 国产成人精品在线播放 | 免费的黄色av | 中文字幕美女免费在线 | 91字幕| 最近2019中文免费高清视频观看www99 | 波多野结衣视频一区二区三区 | 亚洲国产精品成人精品 | 一级黄色在线免费观看 | 黄色软件视频大全免费下载 | 免费视频xnxx com | 色鬼综合网| 国产黄色免费在线观看 | 美女视频久久久 | 欧美激情视频在线观看免费 | 精品久久一区二区三区 | 久久情侣偷拍 | 一二三区高清 | 69国产精品成人在线播放 | 激情av资源 | 久草在线一免费新视频 | 欧美午夜久久 | 国产字幕av | 91精品中文字幕 | 丁香网婷婷 | 国内久久视频 | 国产在线视频一区二区三区 | 国产精品一区一区三区 | 欧美日韩三级在线观看 | av福利在线看 | 免费a视频 | 一区二区影院 | 91av在线视频播放 | 岛国av在线免费 | 人人看人人做人人澡 | 欧美大香线蕉线伊人久久 | 婷婷爱五月天 | 麻豆国产精品va在线观看不卡 | 99热手机在线观看 | 亚洲狠狠丁香婷婷综合久久久 | 日韩精品一区二区免费视频 | 亚洲福利精品 | 菠萝菠萝蜜在线播放 | av黄免费看| 久久精品一区二区三区四区 | 日韩欧美在线不卡 | 91av视频| 激情综合色综合久久 | 色综合久久中文综合久久牛 | 中文电影网 | 日本激情视频中文字幕 | 伊人久久婷婷 | 久久中文精品视频 | 成人三级黄色 | 黄色大片日本免费大片 | 狠狠色综合网站久久久久久久 | 免费在线观看av网站 | 国产最新视频在线 | 中文字幕在线观看网站 | 国产色久 | 91亚洲精品在线 | 91看片在线免费观看 | 免费看特级毛片 | 日韩v欧美v日本v亚洲v国产v | 日本视频高清 | 国产精品高潮在线观看 | 久久精品一区二区三区四区 | a在线免费观看视频 | 色婷婷丁香 | 91完整版观看| 久久在线视频在线 | 精品国产成人av在线免 | 久久综合欧美 | 亚洲视频在线观看免费 | 国产午夜激情视频 | 欧美伦理电影一区二区 | 香蕉视频亚洲 | 精品中文字幕在线 | 中文字幕乱码电影 | 18+视频网站链接 | 久操伊人 |