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

歡迎訪問 生活随笔!

生活随笔

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

数据库

mysql table combine_Mysql系列-性能优化神器EXPLAIN使用介绍及分析

發布時間:2025/4/5 数据库 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql table combine_Mysql系列-性能优化神器EXPLAIN使用介绍及分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MySQL 提供了一個 EXPLAIN 命令, 它可以對?SELECT?語句進行分析, 并輸出?SELECT?執行的詳細信息, 以供開發人員針對性優化。

EXPLAIN 命令用法十分簡單, 在 SELECT 語句前加上 Explain 就可以了, 例如:

EXPLAIN SELECT * from user_info WHERE id < 300;

下面是我結合我自己創建的表以及執行相關sql語句總結的相關知識點。

準備

為了接下來方便演示 EXPLAIN 的使用, 首先我們需要建立兩個測試用的表, 并添加相應的數據:

DROP TABLE IF EXISTS`customers`;CREATE TABLE`customers` (

`customerNumber`int(11) NOT NULL,

`customerName`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`contactLastName`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`contactFirstName`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`phone`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`addressLine1`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`addressLine2`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,

`city`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`state`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,

`postalCode`varchar(15) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,

`country`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`salesRepEmployeeNumber`int(11) NULL DEFAULT NULL,

`creditLimit`decimal(10, 2) NULL DEFAULT NULL,PRIMARY KEY(`customerNumber`) USING BTREE,INDEX`salesRepEmployeeNumber`(`salesRepEmployeeNumber`) USING BTREE,INDEX`customers_idx_combine_1`(`customerName`, `phone`, `customerNumber`) USING BTREE,CONSTRAINT `customers_ibfk_1` FOREIGN KEY (`salesRepEmployeeNumber`) REFERENCES `employees` (`employeeNumber`) ON DELETE RESTRICT ON UPDATE RESTRICT) ENGINE= InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

DROP TABLE IF EXISTS`employees`;CREATE TABLE`employees` (

`employeeNumber`int(11) NOT NULL,

`lastName`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`firstName`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`extension`varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`email`varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`officeCode`varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,

`reportsTo`int(11) NULL DEFAULT NULL,

`jobTitle`varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,PRIMARY KEY(`employeeNumber`) USING BTREE,INDEX`reportsTo`(`reportsTo`) USING BTREE,INDEX`officeCode`(`officeCode`) USING BTREE

) ENGINE= InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

創建表成功后,插入一些測試數據。

EXPLAIN 輸出格式

EXPLAIN 命令的輸出內容大致如下:

mysql> EXPLAIN SELECT * FROM customers WHERE customerName='Herkku Gifts' AND phone='+47 2267 3215' AND customerNumber=167;+----+-------------+-----------+------------+-------+---------------------------------+---------+---------+-------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------------------------+---------+---------+-------+------+----------+-------+

| 1 | SIMPLE | customers | NULL | const | PRIMARY,customers_idx_combine_1 | PRIMARY | 4 | const | 1 | 100.00 | NULL |

+----+-------------+-----------+------------+-------+---------------------------------+---------+---------+-------+------+----------+-------+

1 row in set, 1 warning (0.00 sec)

各列的含義如下:

id: SELECT 查詢的標識符. 每個 SELECT 都會自動分配一個唯一的標識符

select_type: SELECT 查詢的類型

table: 查詢的是哪個表

partitions: 匹配的分區

type: join 類型

possible_keys: 此次查詢中可能選用的索引

key: 此次查詢中確切使用到的索引

ken_len:?表示查詢優化器使用了索引的字節數

ref: 哪個字段或常數與 key 一起被使用

rows: 顯示此查詢一共掃描了多少行. 這個是一個估計值.

filtered: 表示此查詢條件所過濾的數據的百分比

extra: 額外的信息

接下來我們詳細看一下每個字段的具體含義:

select_type

select_type?表示了查詢的類型, 它的常用取值有:

SIMPLE:表示此查詢不包含 UNION 查詢或子查詢

PRIMARY:表示此查詢是最外層的查詢

UNION:表示此查詢是 UNION 的第二或隨后的查詢

DEPENDENT UNION:UNION 中的第二個或后面的查詢語句, 取決于外面的查詢

UNION RESULT:UNION 的結果

SUBQUERY:子查詢中的第一個 SELECT

DEPENDENT SUBQUERY:子查詢中的第一個 SELECT, 取決于外面的查詢. 即子查詢依賴于外層查詢的結果

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

最常見的查詢類別應該是?SIMPLE了, 比如當我們的查詢沒有子查詢, 也沒有 UNION 查詢時, 那么通常就是?SIMPLE類型, 例如:

1.SIMPLE?情況:

mysql> EXPLAIN SELECT * FROM customers WHERE customerName='Herkku Gifts' AND phone='+47 2267 3215' AND customerNumber=167;+----+-------------+-----------+------------+-------+---------------------------------+---------+---------+-------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------------------------+---------+---------+-------+------+----------+-------+

| 1 | SIMPLE | customers | NULL | const | PRIMARY,customers_idx_combine_1 | PRIMARY | 4 | const | 1 | 100.00 | NULL |

+----+-------------+-----------+------------+-------+---------------------------------+---------+---------+-------+------+----------+-------+

1 row in set, 1 warning (0.00 sec)

2.UNION情況

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

mysql> EXPLAIN SELECT customerNumber FROM customers WHERE customerNumber IN (125,144) UNION SELECT customerNumber FROM customers WHERE country IN ('USA','France');+----+--------------+------------+------------+-------+---------------+---------+---------+------+------+----------+--------------------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+--------------+------------+------------+-------+---------------+---------+---------+------+------+----------+--------------------------+

| 1 | PRIMARY | customers | NULL | range | PRIMARY | PRIMARY | 4 | NULL | 2 | 100.00 | Using where; Using index |

| 2 | UNION | customers | NULL | ALL | NULL | NULL | NULL | NULL | 122 | 20.00 | Using where |

| NULL | UNION RESULT | | NULL | ALL | NULL | NULL | NULL | NULL | NULL | NULL | Using temporary |

+----+--------------+------------+------------+-------+---------------+---------+---------+------+------+----------+--------------------------+

3 rows in set, 1 warning (0.00 sec)

3.DEPENDENT UNION與DEPENDENT SUBQUERY

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

mysql> EXPLAIN SELECT * FROM customers WHERE customerNumber IN (SELECT customerNumber FROM customers WHERE customerNumber IN (125,144) UNION SELECT customerNumber FROM customers WHERE country IN ('USA','France'));+----+--------------------+------------+------------+--------+---------------+---------+---------+------+------+----------+--------------------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+--------------------+------------+------------+--------+---------------+---------+---------+------+------+----------+--------------------------+

| 1 | PRIMARY | customers | NULL | ALL | NULL | NULL | NULL | NULL | 122 | 100.00 | Using where |

| 2 | DEPENDENT SUBQUERY | customers | NULL | eq_ref | PRIMARY | PRIMARY | 4 | func | 1 | 100.00 | Using where; Using index |

| 3 | DEPENDENT UNION | customers | NULL | eq_ref | PRIMARY | PRIMARY | 4 | func | 1 | 20.00 | Using where |

| NULL | UNION RESULT | | NULL | ALL | NULL | NULL | NULL | NULL | NULL | NULL | Using temporary |

+----+--------------------+------------+------------+--------+---------------+---------+---------+------+------+----------+--------------------------+

4 rows in set, 1 warning (0.00 sec)

4.SUBQUERY

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

mysql> EXPLAIN SELECT * FROM customers WHERE customerNumber=(SELECT customerNumber FROM customers WHERE customerNumber=124);+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

| 1 | PRIMARY | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | NULL |

| 2 | SUBQUERY | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | Using index |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

2 rows in set, 1 warning (0.00sec)

mysql> EXPLAIN SELECT * FROM customers WHERE customerNumber in (SELECT customerNumber FROM customers WHERE customerNumber=124);+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

| 1 | SIMPLE | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | NULL |

| 1 | SIMPLE | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | Using index |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

2 rows in set, 1 warning (0.00 sec)

思考下為什么一個用了in一個用了=反而select_type就不一樣了????

5.DERIVED

mysql> EXPLAIN SELECT * FROM (SELECT COUNT(*) FROM customers WHERE customerNumber=124) a;+----+-------------+------------+------------+--------+---------------+---------+---------+-------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+------------+------------+--------+---------------+---------+---------+-------+------+----------+-------------+

| 1 | PRIMARY | | NULL | system | NULL | NULL | NULL | NULL | 1 | 100.00 | NULL |

| 2 | DERIVED | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | Using index |

+----+-------------+------------+------------+--------+---------------+---------+---------+-------+------+----------+-------------+

2 rows in set, 1 warning (0.00 sec)

table

表示查詢涉及的表或衍生表

partitions

匹配的分區

type

type字段比較重要, 顯示連接使用了何種類型。從最好到最差的連接類型依次分別為const、eq_reg、ref、range、index和ALL它提供了判斷查詢是否高效的重要依據依據。

通過?type字段, 我們判斷此次查詢是?全表掃描?還是?索引掃描?等。

type顯示的是訪問類型,是較為重要的一個指標,結果值從好到壞依次是:system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL

一般來說,得保證查詢至少達到range級別,最好能達到ref。

type常用的取值有:

system: 表中只有一條數據. 這個類型是特殊的?const類型。

const: 針對主鍵或唯一索引的等值查詢掃描, 最多只返回一行數據。const 查詢速度非常快, 因為它僅僅讀取一次即可。

表示通過索引一次就找到了,const用于比較primary key 或者 unique索引。因為只需匹配一行數據,所有很快。如果將主鍵置于where列表中,mysql就能將該查詢轉換為一個const 。

例如下面的這個查詢, 它使用了主鍵索引, 因此?type就是?const類型的

mysql> EXPLAIN SELECT * FROM customers WHERE customerNumber=128;+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------+

| 1 | SIMPLE | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | NULL |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------+

1 row in set, 1 warning (0.00 sec)

eq_ref:唯一性索引掃描,對于每個索引鍵,表中只有一條記錄與之匹配。常見于主鍵 或 唯一索引掃描。

mysql> SELECT * FROMitems;+----+---------+

| id | item_no |

+----+---------+

| 1 | A-1 |

| 2 | A-2 |

| 3 | A-3 |

| 4 | A-4 |

| 5 | A-5 |

| 6 | A-10 |

| 7 | A-11 |

| 8 | A-20 |

| 9 | A-30 |

+----+---------+

9 rows in set (0.00 sec)

mysql> SELECT * FROM customers LIMIT 10;+----------------+------------------------------+-----------------+------------------+-------------------+------------------------------+--------------+---------------+----------+------------+-----------+------------------------+-------------+

| customerNumber | customerName | contactLastName | contactFirstName | phone | addressLine1 | addressLine2 | city | state | postalCode | country | salesRepEmployeeNumber | creditLimit |

+----------------+------------------------------+-----------------+------------------+-------------------+------------------------------+--------------+---------------+----------+------------+-----------+------------------------+-------------+

| 103 | Atelier graphique | Schmitt | Carine | 40.32.2555 | 54, rue Royale | NULL | Nantes | NULL | 44000 | France | 1370 | 21000.00 |

| 112 | Signal Gift Stores | King | Jean | 7025551838 | 8489 Strong St. | NULL | Las Vegas | NV | 83030 | USA | 1166 | 71800.00 |

| 114 | Australian Collectors, Co. | Ferguson | Peter | 03 9520 4555 | 636 St Kilda Road | Level 3 | Melbourne | Victoria | 3004 | Australia | 1611 | 117300.00 |

| 119 | La Rochelle Gifts | Labrune | Janine | 40.67.8555 | 67, rue des Cinquante Otages | NULL | Nantes | NULL | 44000 | France | 1370 | 118200.00 |

| 121 | Baane Mini Imports | Bergulfsen | Jonas | 07-98 9555 | Erling Skakkes gate 78 | NULL | Stavern | NULL | 4110 | Norway | 1504 | 81700.00 |

| 124 | Mini Gifts Distributors Ltd. | Nelson | Susan | 4155551450 | 5677 Strong St. | NULL | San Rafael | CA | 97562 | USA | 1165 | 210500.00 |

| 125 | Havel & Zbyszek Co | Piestrzeniewicz | Zbyszek | (26) 642-7555 | ul. Filtrowa 68 | NULL | Warszawa | NULL | 01-012 | Poland | NULL | 0.00 |

| 128 | Blauer See Auto, Co. | Keitel | Roland | +49 69 66 90 2555 | Lyonerstr. 34 | NULL | Frankfurt | NULL | 60528 | Germany | 1504 | 59700.00 |

| 129 | Mini Wheels Co. | Murphy | Julie | 6505555787 | 5557 North Pendale Street | NULL | San Francisco | CA | 94217 | USA | 1165 | 64600.00 |

| 131 | Land of Toys Inc. | Lee | Kwai | 2125557818 | 897 Long Airport Avenue | NULL | NYC | NY | 10022 | USA | 1323 | 114900.00 |

+----------------+------------------------------+-----------------+------------------+-------------------+------------------------------+--------------+---------------+----------+------------+-----------+------------------------+-------------+

10 rows in set (0.00 sec)

mysql> EXPLAIN SELECT * FROM items,customers WHERE customers.customerNumber=items.id;+----+-------------+-----------+------------+--------+---------------+---------+---------+-------------------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+--------+---------------+---------+---------+-------------------+------+----------+-------+

| 1 | SIMPLE | items | NULL | ALL | PRIMARY | NULL | NULL | NULL | 9 | 100.00 | NULL |

| 1 | SIMPLE | customers | NULL | eq_ref | PRIMARY | PRIMARY | 4 | yiibaidb.items.id | 1 | 100.00 | NULL |

+----+-------------+-----------+------------+--------+---------------+---------+---------+-------------------+------+----------+-------+

2 rows in set, 1 warning (0.00 sec)

注意:ALL全表掃描的表是記錄最少的表如items表。

ref:非唯一性索引掃描,返回匹配某個單獨值的所有行。本質是也是一種索引訪問,它返回所有匹配某個單獨值的行,然而他可能會找到多個符合條件的行,所以它應該屬于查找和掃描的混合體 。

mysql> SELECT * FROM customers WHERE salesRepEmployeeNumber=1165;+----------------+------------------------------+-----------------+------------------+------------+---------------------------+--------------+---------------+-------+------------+---------+------------------------+-------------+

| customerNumber | customerName | contactLastName | contactFirstName | phone | addressLine1 | addressLine2 | city | state | postalCode | country | salesRepEmployeeNumber | creditLimit |

+----------------+------------------------------+-----------------+------------------+------------+---------------------------+--------------+---------------+-------+------------+---------+------------------------+-------------+

| 124 | Mini Gifts Distributors Ltd. | Nelson | Susan | 4155551450 | 5677 Strong St. | NULL | San Rafael | CA | 97562 | USA | 1165 | 210500.00 |

| 129 | Mini Wheels Co. | Murphy | Julie | 6505555787 | 5557 North Pendale Street | NULL | San Francisco | CA | 94217 | USA | 1165 | 64600.00 |

| 161 | Technics Stores Inc. | Hashimoto | Juri | 6505556809 | 9408 Furth Circle | NULL | Burlingame | CA | 94217 | USA | 1165 | 84600.00 |

| 321 | Corporate Gift Ideas Co. | Brown | Julie | 6505551386 | 7734 Strong St. | NULL | San Francisco | CA | 94217 | USA | 1165 | 105000.00 |

| 450 | The Sharp Gifts Warehouse | Frick | Sue | 4085553659 | 3086 Ingle Ln. | NULL | San Jose | CA | 94217 | USA | 1165 | 77600.00 |

| 487 | Signal Collectibles Ltd. | Taylor | Sue | 4155554312 | 2793 Furth Circle | NULL | Brisbane | CA | 94217 | USA | 1165 | 60300.00 |

+----------------+------------------------------+-----------------+------------------+------------+---------------------------+--------------+---------------+-------+------------+---------+------------------------+-------------+

6 rows in set (0.00sec)

mysql> EXPLAIN SELECT * FROM customers WHERE salesRepEmployeeNumber=1165;+----+-------------+-----------+------------+------+------------------------+------------------------+---------+-------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+------+------------------------+------------------------+---------+-------+------+----------+-------+

| 1 | SIMPLE | customers | NULL | ref | salesRepEmployeeNumber| salesRepEmployeeNumber | 5 | const | 6 | 100.00 | NULL |

+----+-------------+-----------+------------+------+------------------------+------------------------+---------+-------+------+----------+-------+

1 row in set, 1 warning (0.00 sec)

mysql> show index fromcustomers;+-----------+------------+-------------------------+--------------+------------------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |

+-----------+------------+-------------------------+--------------+------------------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| customers | 0 | PRIMARY | 1 | customerNumber | A | 122 | NULL | NULL | | BTREE | | |

| customers | 1 | salesRepEmployeeNumber | 1 | salesRepEmployeeNumber| A | 16 | NULL | NULL | YES | BTREE | | |

| customers | 1 | customers_idx_combine_1 | 1 | customerName | A | 122 | NULL | NULL | | BTREE | | |

| customers | 1 | customers_idx_combine_1 | 2 | phone | A | 122 | NULL | NULL | | BTREE | | |

| customers | 1 | customers_idx_combine_1 | 3 | customerNumber | A | 122 | NULL | NULL | | BTREE | | |

+-----------+------------+-------------------------+--------------+------------------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

5 rows in set (0.00 sec)

range:只檢索給定范圍的行,使用一個索引來選擇行。key列顯示使用了那個索引。一般就是在where語句中出現了bettween、、in等的查詢。這種索引列上的范圍掃描比全索引掃描要好。只需要開始于某個點,結束于另一個點,不用掃描全部索引 。

mysql> EXPLAIN SELECT * FROM customers WHERE customerNumber BETWEEN 1 AND 120;+----+-------------+-----------+------------+-------+---------------+---------+---------+------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+---------+---------+------+------+----------+-------------+

| 1 | SIMPLE | customers | NULL | range | PRIMARY | PRIMARY | 4 | NULL | 4 | 100.00 | Using where |

+----+-------------+-----------+------------+-------+---------------+---------+---------+------+------+----------+-------------+

1 row in set, 1 warning (0.00 sec)

index:Full Index Scan,index與ALL區別為index類型只遍歷索引樹。這通常為ALL快,因為索引文件通常比數據文件小。(Index與ALL雖然都是讀全表,但index是從索引中讀取,而ALL是從硬盤讀取) 。

mysql> EXPLAIN SELECT id FROMitems;+----+-------------+-------+------------+-------+---------------+---------+---------+------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-------+------------+-------+---------------+---------+---------+------+------+----------+-------------+

| 1 | SIMPLE | items | NULL | index| NULL | PRIMARY | 4 | NULL | 9 | 100.00 | Using index |

+----+-------------+-------+------------+-------+---------------+---------+---------+------+------+----------+-------------+

1 row in set, 1 warning (0.00sec)

mysql> show index fromitems;+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |

+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| items | 0 | PRIMARY | 1 | id | A | 9 | NULL | NULL | | BTREE | | |

+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

1 row in set (0.00 sec)

ALL:Full Table Scan,遍歷全表以找到匹配的行 。

mysql> EXPLAIN SELECT item_no FROMitems;+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+

| 1 | SIMPLE | items | NULL | ALL | NULL | NULL | NULL | NULL | 9 | 100.00 | NULL |

+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------+

1 row in set, 1 warning (0.00sec)

mysql> show index fromitems;+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |

+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| items | 0 | PRIMARY | 1 | id | A | 9 | NULL | NULL | | BTREE | | |

+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

1 row in set (0.00 sec)

possible_keys

查詢涉及到的字段上存在索引,則該索引將被列出,但不一定被查詢實際使用。

key

實際使用的索引,如果為NULL,則沒有使用索引。

查詢中如果使用了覆蓋索引,則該索引僅出現在key列表中。

mysql> show index fromcustomers;+-----------+------------+-------------------------+--------------+------------------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |

+-----------+------------+-------------------------+--------------+------------------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

| customers | 0 | PRIMARY | 1 | customerNumber | A | 122 | NULL | NULL | | BTREE | | |

| customers | 1 | salesRepEmployeeNumber | 1 | salesRepEmployeeNumber | A | 16 | NULL | NULL | YES | BTREE | | |

| customers | 1 | customers_idx_combine_1 | 1 | customerName | A | 122 | NULL | NULL | | BTREE | | |

| customers | 1 | customers_idx_combine_1 | 2 | phone | A | 122 | NULL | NULL | | BTREE | | |

| customers | 1 | customers_idx_combine_1 | 3 | customerNumber | A | 122 | NULL | NULL | | BTREE | | |

+-----------+------------+-------------------------+--------------+------------------------+-----------+-------------+----------+--------+------+------------+---------+---------------+

5 rows in set (0.00sec)

mysql> EXPLAIN SELECT customerName,phone,customerNumber fromcustomers;+----+-------------+-----------+------------+-------+---------------+-------------------------+---------+------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+-------------------------+---------+------+------+----------+-------------+

| 1 | SIMPLE | customers | NULL | index | NULL | customers_idx_combine_1 | 308 | NULL | 122 | 100.00 | Using index |

+----+-------------+-----------+------------+-------+---------------+-------------------------+---------+------+------+----------+-------------+

1 row in set, 1 warning (0.00 sec)

上述customerName,phone,customerNumber與customers_idx_combine_1索引順序一致,為覆蓋索引

mysql> EXPLAIN SELECT phone,customerName,customerNumber fromcustomers;+----+-------------+-----------+------------+-------+---------------+-------------------------+---------+------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+-------------------------+---------+------+------+----------+-------------+

| 1 | SIMPLE | customers | NULL | index | NULL | customers_idx_combine_1 | 308 | NULL | 122 | 100.00 | Using index |

+----+-------------+-----------+------------+-------+---------------+-------------------------+---------+------+------+----------+-------------+

1 row in set, 1 warning (0.00 sec)

mysql> EXPLAIN SELECT customerName,phone,customerNumber,state fromcustomers;+----+-------------+-----------+------------+------+---------------+------+---------+------+------+----------+-------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+------+---------------+------+---------+------+------+----------+-------+

| 1 | SIMPLE | customers | NULL |ALL | NULL | NULL | NULL | NULL | 122 | 100.00 | NULL |

+----+-------------+-----------+------------+------+---------------+------+---------+------+------+----------+-------+

1 row in set, 1 warning (0.00 sec)

state字段為非索引列。

key_len

表示索引中使用的字節數,查詢中使用的索引的長度(最大可能長度),并非實際使用長度,理論上長度越短越好。key_len是根據表定義計算而得的,不是通過表內檢索出的。

ref

顯示索引的那一列被使用了,如果可能,是一個常量const。

mysql> EXPLAIN SELECT customerNumber FROM customers WHERE customerNumber=114;+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

| 1 | SIMPLE | customers | NULL | const | PRIMARY | PRIMARY | 4 | const | 1 | 100.00 | Using index |

+----+-------------+-----------+------------+-------+---------------+---------+---------+-------+------+----------+-------------+

1 row in set, 1 warning (0.00 sec)

rows

根據表統計信息及索引選用情況,大致估算出找到所需的記錄所需要讀取的行數。

Extra

不適合在其他字段中顯示,但是十分重要的額外信息。

Using filesort?:mysql對數據使用一個外部的索引排序,而不是按照表內的索引進行排序讀取。也就是說mysql無法利用索引完成的排序操作成為“文件排序” 。

總結

以上是生活随笔為你收集整理的mysql table combine_Mysql系列-性能优化神器EXPLAIN使用介绍及分析的全部內容,希望文章能夠幫你解決所遇到的問題。

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

天天爱天天干天天爽 | 色婷婷狠狠五月综合天色拍 | 丁香九月婷婷 | 国产精品久久久久久久久久东京 | 日韩国产在线观看 | 天天摸天天干天天操天天射 | 午夜视频在线观看一区二区 | 国产在线传媒 | 久久综合中文字幕 | 欧美在线视频一区二区三区 | 色综合天天色 | 国产视频在线免费 | 密桃av在线 | 99久久婷婷国产综合精品 | 欧美一级性生活 | 国产精品一区二区美女视频免费看 | 成人午夜电影网站 | 91综合久久一区二区 | 国产精品精品视频 | 最新av观看 | 麻豆视频入口 | 欧美日韩视频一区二区三区 | 国产高清福利在线 | a在线播放| 日韩中文字幕亚洲一区二区va在线 | 国产视频欧美视频 | 欧美日韩另类视频 | 91免费视频国产 | 中文av网站| 欧美一区日韩一区 | 久久久久亚洲最大xxxx | 五月天色婷婷丁香 | 久久久久日本精品一区二区三区 | 亚洲黄色在线观看 | 黄色大片免费网站 | 亚洲精品午夜视频 | 99久久精品国产一区 | 久久久官网| 亚洲精品综合一二三区在线观看 | 91看片在线免费观看 | 97超级碰| 国产精品永久在线观看 | 欧美婷婷色 | www.亚洲黄| 日韩欧美极品 | 日批视频在线 | 久久天天躁夜夜躁狠狠躁2022 | 黄污视频网站 | 精品日韩在线 | 久久少妇av| 欧美日韩一区二区三区不卡 | 天天操天天干天天玩 | 国产96视频 | 五月婷婷综合在线观看 | 国产高清第一页 | 在线观看亚洲 | 久久免费视频在线观看 | 精品国产乱码久久久久久浪潮 | 免费视频 三区 | 国产婷婷色 | 中文字幕在线观看网址 | 在线看av网址 | 精品国产一区二区三区日日嗨 | 97香蕉超级碰碰久久免费软件 | 五月天综合网站 | 国产视频精品免费 | 国产精品成人一区二区三区 | 国产 在线观看 | av福利免费 | 黄色一级在线视频 | 国内精品在线看 | 亚洲欧洲精品一区二区 | av成人资源| 欧美亚洲成人xxx | 日本精品午夜 | 久草在线视频免费资源观看 | 日本精品中文字幕在线观看 | 欧美激情在线看 | av网站有哪些 | av大全在线免费观看 | 免费日韩视 | 色婷婷在线播放 | 精品久久久久久久久久久院品网 | 久久国产精品视频 | 免费视频一区 | 热99在线| 在线免费黄 | 欧美日韩高清一区二区 国产亚洲免费看 | 亚洲国产欧美一区二区三区丁香婷 | 黄色www| 久久9999久久免费精品国产 | 色婷婷视频网 | 亚洲片在线 | 十八岁以下禁止观看的1000个网站 | av在线最新 | 久久国产精品一区二区三区四区 | 丁香婷婷激情网 | 久久精品91久久久久久再现 | 99视频网站 | 91av在线免费 | 亚洲午夜精品久久久 | 狠狠操天天操 | 超碰午夜 | 97国产在线播放 | 精品国偷自产国产一区 | 国产在线播放不卡 | 日韩精品一区二区三区高清免费 | 国产在线播放观看 | 91看片在线观看 | 五月婷婷综合在线 | 天天操综合 | 国产日产精品一区二区三区四区的观看方式 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 91香蕉亚洲精品 | 国产在线播放不卡 | aaa免费毛片 | 国产录像在线观看 | 国产一级在线看 | 国产无吗一区二区三区在线欢 | 91中文字幕在线观看 | 500部大龄熟乱视频 欧美日本三级 | 免费观看一级视频 | 亚洲精品字幕在线观看 | 毛片网在线观看 | 国产人成在线观看 | 久久精品com | 久久久久在线 | 精品久久久久久久久久久久久 | 日本激情动作片免费看 | 午夜色站 | 国产专区日韩专区 | 精品国产91亚洲一区二区三区www | 在线观看日韩免费视频 | 久久精选视频 | av一区二区在线观看中文字幕 | 免费在线观看亚洲视频 | 久久久999 | 91av在线免费看 | 精品久久1 | av在线永久免费观看 | 亚洲精品一区二区在线观看 | 天堂视频中文在线 | 婷婷.com| 亚洲精品国产精品国自产在线 | 九七在线视频 | 久久午夜影视 | 久久精品永久免费 | 国产精品99久久久久久人免费 | 久久视频热| 亚洲一区尤物 | 激情综合啪啪 | 夜夜操天天操 | 999久久a精品合区久久久 | 亚洲天天 | 啪啪小视频网站 | 在线v片免费观看视频 | 色午夜| 国产裸体无遮挡 | 日韩电影中文字幕 | 国产成人精品av久久 | 国产精品久久伊人 | www国产精品com| 国产精品一区二区三区视频免费 | 亚洲91在线 | 国产日韩精品一区二区 | 国产成人精品在线播放 | 精品国产电影一区 | 91视频首页| 在线观看视频一区二区三区 | 欧美日韩国语 | 日日夜夜狠狠 | 欧美日韩在线观看一区 | av免费看av| 国产青青青 | 久久久久亚洲a | 黄色日视频 | 欧美午夜久久 | 色偷偷网站视频 | 99精品视频播放 | 国产在线视频一区二区 | 国产精品成人自拍 | 国产美女网站视频 | 国产伦精品一区二区三区免费 | 五月天婷婷视频 | 在线亚洲欧美日韩 | 在线免费观看成人 | 国内精品久久久久久中文字幕 | 免费观看性生交 | 日韩激情小视频 | 欧美成人xxxx | 五月婷婷操 | 久久久网页 | 午夜精品剧场 | 国产欧美高清 | 欧美性猛片, | 日韩日韩日韩日韩 | 免费看成人 | 亚洲欧洲成人精品av97 | 91精品国产99久久久久久红楼 | 三级av中文字幕 | 黄色片视频在线观看 | 1024久久| 狠狠狠色 | 亚洲乱码精品久久久久 | 成人网大片 | 日韩一区二区三区免费视频 | 亚洲视屏在线播放 | 亚洲精品视频偷拍 | 国产免费观看视频 | 欧美a级成人淫片免费看 | 豆豆色资源网xfplay | 夜夜操天天摸 | 欧美精品久久久久久久免费 | 91丨九色丨蝌蚪丨对白 | 日韩18p| 久久福利剧场 | 色婷婷视频| 中文字幕国产精品一区二区 | 99久久日韩精品免费热麻豆美女 | 国产区网址 | 99热在线精品观看 | 日韩丝袜在线 | 中文字幕美女免费在线 | 精精国产xxxx视频在线播放 | 久久国产91| 久久国产成人午夜av影院宅 | 99免费在线观看 | 婷婷综合激情 | 久久爱992xxoo | 国产精品毛片一区二区三区 | 国产视频一区精品 | 在线国产精品视频 | 成人久久毛片 | 天天色天天 | 四川妇女搡bbbb搡bbbb搡 | 4438全国亚洲精品在线观看视频 | 久久国产精品99久久久久久丝袜 | 韩国av免费在线观看 | avcom在线| 蜜臀av在线一区二区三区 | 丁香花在线观看视频在线 | 国产亚洲精品成人 | a√资源在线 | 欧美在线free | 久视频在线 | 人人射人人插 | 黄色大片免费网站 | 99re国产| 啪啪动态视频 | 欧美成人黄色片 | 日韩夜夜爽 | 婷婷免费在线视频 | 国产亚洲精品久久久久久久久久 | 三级av在线免费观看 | 欧美a影视 | 91丝袜美腿 | 国产精彩视频一区二区 | 天天综合色 | 91成年视频| 久久午夜精品影院一区 | 欧美激情xxxx性bbbb | 黄色成人毛片 | 日韩三区在线观看 | 97国产精品视频 | 免费成视频| 狠狠狠狠狠狠干 | 在线观看视频一区二区三区 | 午夜精品剧场 | 一级黄色片在线观看 | 日本特黄特色aaa大片免费 | 99精品一区| 久久精品视频在线观看 | 国产精品亚洲片在线播放 | 日韩成人精品一区二区三区 | 久久最新 | 一区三区视频在线观看 | 黄色av免费电影 | 狠狠精品 | 黄色不卡av | 中文字幕九九 | 狠狠88综合久久久久综合网 | 国内毛片毛片 | 亚洲精品在线一区二区 | 在线免费黄色片 | 麻豆视频在线播放 | 992tv在线 | 欧美视屏一区二区 | 婷婷色资源| 国产一区二区久久 | 欧美精品九九99久久 | 丁香色婷婷 | 成人国产电影在线观看 | 中文字幕一区二区三区久久蜜桃 | 国产一区国产二区在线观看 | 亚洲日本国产精品 | 婷婷激情站 | 日日干激情五月 | 黄色日本免费 | av片在线看 | 99国产一区二区三精品乱码 | 日韩欧美精选 | 欧美国产日韩一区二区三区 | 久久在现视频 | 五月天婷婷在线视频 | 亚洲精品视频在线免费 | 免费久草视频 | 日韩高清在线一区二区三区 | 日韩中文字幕亚洲一区二区va在线 | 黄色小说视频在线 | 在线视频 国产 日韩 | 久久婷婷视频 | 欧美国产日韩在线观看 | 五月天婷婷在线播放 | 黄网av在线| 免费在线观看av电影 | 日韩av资源在线观看 | 美女视频黄免费的久久 | 91精品国产91热久久久做人人 | 精品国内 | 国产精品免费观看网站 | 亚洲日本成人 | 免费性网站 | 一区二区三区免费在线观看视频 | 国产精品久久久久久久久久直播 | 成人免费观看a | 久久久久久久免费观看 | 婷婷在线播放 | 毛片视频网址 | 久久国产精品99国产精 | 国产精品欧美久久久久无广告 | 久久深夜 | 欧美视频不卡 | 婷婷六月中文字幕 | 久久久精品国产一区二区电影四季 | 狠狠操天天射 | 日日激情 | 天天综合天天做天天综合 | 99在线免费视频观看 | 日韩精品视频在线观看网址 | 天天插狠狠插 | 久久久久久久久影视 | 在线观看电影av | 九九亚洲精品 | 91在线播 | 国产不卡免费视频 | 毛片精品免费在线观看 | 欧美精品在线观看免费 | 国产一区在线播放 | 黄色com | 黄色精品一区 | 中文字幕中文字幕中文字幕 | 人人玩人人添人人澡超碰 | 成人 亚洲 欧美 | 日韩在线视频网 | av成人免费观看 | 久久久综合香蕉尹人综合网 | 久久99精品一区二区三区三区 | 在线免费中文字幕 | 丁香在线视频 | 中文字幕日韩免费视频 | 一区二区不卡视频在线观看 | 日韩小视频网站 | 亚洲精品白浆高清久久久久久 | 久久人人爽人人爽人人片 | 久久夜av | 亚洲人人精品 | 一区二区三区在线影院 | 国产精品一二 | 久草在线资源观看 | 日韩亚洲精品电影 | www国产亚洲精品久久麻豆 | 国产在线观看xxx | 欧美日韩中文国产一区发布 | 久草免费在线视频观看 | 日本激情动作片免费看 | 国产精品麻豆视频 | 国产999精品久久久影片官网 | 婷婷 综合 色 | 国产成人精品免高潮在线观看 | 亚洲精品乱码久久久一二三 | 激情五月婷婷综合网 | 亚洲精品资源 | 日韩中文字幕网站 | 久久天天躁狠狠躁亚洲综合公司 | 激情综合网五月婷婷 | 又黄又网站 | 国产一区二区高清视频 | 亚洲国产成人精品在线 | 欧美激情精品久久久久久 | 久久久国产精品久久久 | 91久久电影 | 国产99中文字幕 | 欧美一区二区三区特黄 | 日黄网站 | 国产二区视频在线 | 午夜少妇av | 久操操| 亚洲伦理一区 | 久久久久久久久久久久影院 | 国产精品av免费在线观看 | 日本黄色大片免费 | 中文视频在线看 | 在线电影播放 | 国产手机视频在线播放 | 丝袜制服综合网 | 国内精品久久久久久久久久清纯 | 91精品在线观看视频 | 在线观看视频精品 | 久久精品韩国 | 黄色三级免费片 | 91色亚洲 | 中字幕视频在线永久在线观看免费 | 在线观看韩日电影免费 | 懂色av懂色av粉嫩av分享吧 | 免费成视频 | 激情欧美在线观看 | 欧美另类xxxxx | 国产精品99在线播放 | 亚洲人成在 | 亚洲综合网站在线观看 | 黄色大片日本免费大片 | 亚洲精品欧美成人 | 成人欧美一区二区三区在线观看 | 欧美日在线 | av在线免费网 | 欧美一级视频免费 | 日韩免费中文 | 在线免费观看视频一区二区三区 | 国产成人资源 | 亚洲一区二区三区在线看 | 日韩精品视频免费专区在线播放 | 九九免费在线观看 | 在线亚洲欧美日韩 | 国产综合在线观看视频 | 超碰在线99 | 久久精品这里精品 | 日韩三级成人 | 一级免费观看 | 香蕉视频久久久 | 在线成人av | 国产色 在线 | 免费福利在线播放 | 欧美国产不卡 | 亚洲免费资源 | 亚洲专区路线二 | 久久精选视频 | 最新日韩在线观看视频 | 人人狠狠综合久久亚洲 | 伊人五月综合 | 免费男女羞羞的视频网站中文字幕 | 天天爽综合网 | 国产精品久久久免费看 | 久久久久久综合网天天 | 欧美在线视频一区二区三区 | 国产韩国日本高清视频 | 成人在线免费观看网站 | 成人av电影免费 | 欧美a免费 | 国产精品不卡视频 | 日韩电影中文字幕 | 欧美亚洲成人免费 | 成人午夜电影在线观看 | 亚欧洲精品视频在线观看 | 亚洲午夜久久久久 | 亚洲欧美日韩国产一区二区三区 | 成人97视频一区二区 | 亚洲1区 在线 | 久久视频一区二区 | 在线 影视 一区 | 久草视频视频在线播放 | 欧美地下肉体性派对 | 国产一级二级在线播放 | 91一区啪爱嗯打偷拍欧美 | 1000部18岁以下禁看视频 | 欧美国产视频在线 | 毛片1000部免费看 | 婷婷伊人五月 | 在线视频精品播放 | 久久久久国产免费免费 | 亚洲成人黄 | 日日夜夜91 | 亚洲综合国产精品 | 韩国精品在线观看 | 美国av大片 | 国产精品青青 | 国产精品久久一区二区三区, | 麻豆你懂的| 六月丁香在线观看 | 久草视频在线资源站 | 日日碰狠狠躁久久躁综合网 | 成年人免费在线观看 | 不卡电影免费在线播放一区 | 日韩在线观看视频免费 | 久草视频在线资源 | 久久精品最新 | 亚洲精品玖玖玖av在线看 | 国产99久久久国产精品 | 久久综合欧美精品亚洲一区 | 96精品高清视频在线观看软件特色 | 国产91在线观看 | 波多野结衣理论片 | av大片免费在线观看 | 狠狠色狠狠色综合日日92 | 久草在线视频网站 | 99这里只有精品99 | 午夜av影院| av中文在线观看 | 欧美日韩高清在线一区 | 日韩最新中文字幕 | 久久99精品一区二区三区三区 | 国产精品理论片在线观看 | 香蕉视频在线播放 | 久久av网| 99视频在线观看视频 | 色网站国产精品 | 天天伊人网 | 国产99久久九九精品免费 | 久草免费在线视频观看 | 日韩精品视频在线免费观看 | 高清精品在线 | 在线精品视频免费观看 | 中文字幕乱偷在线 | 在线成人观看 | 91伊人久久大香线蕉蜜芽人口 | 亚洲高清国产视频 | www激情com | 免费在线观看视频一区 | 免费男女网站 | 成人香蕉视频 | 日韩中文在线播放 | 欧美大片在线看免费观看 | 亚洲精欧美一区二区精品 | 亚洲精品小视频在线观看 | 天天综合天天综合 | 日韩三级视频在线观看 | 麻花豆传媒一二三产区 | 免费污片| 久久污视频 | 色播99 | 91在线观看欧美日韩 | 亚洲无在线| 亚洲老妇xxxxxx | 韩国在线视频一区 | 欧美日本三级 | 99热99re6国产在线播放 | 成人av片免费看 | 蜜臀91丨九色丨蝌蚪老版 | 91麻豆精品国产91久久久更新时间 | 免费高清国产 | 超碰在线人人爱 | 成人久久久久久久久 | 91精品国产自产在线观看永久 | 麻豆国产露脸在线观看 | 男女视频91 | 免费a视频在线 | 日韩精品视频第一页 | 欧美日韩一区二区三区免费视频 | 超碰在线天天 | 欧美成年网站 | 中文字幕黄色网 | 国产91精品一区二区绿帽 | 亚洲一区黄色 | 蜜臀久久99精品久久久久久网站 | 亚洲国产伊人 | 色婷婷在线播放 | 亚洲精品18日本一区app | 免费看黄的 | 久要激情网| 91精品国产综合久久婷婷香蕉 | av线上看| 国内久久精品 | 黄色网址中文字幕 | 久久精品久久久精品美女 | 亚洲理论电影 | 精品视频久久久 | 五月开心婷婷 | 91视频88av | 日b视频国产 | 日韩久久激情 | av观看久久久 | 成人在线观看av | 国产精品自产拍 | 久久99视频 | 中文字幕九九 | 亚洲精品中文在线 | 性色xxxxhd | av成年人电影 | 免费看成人片 | 日韩免费| 免费视频一区二区 | 97在线观看免费高清完整版在线观看 | 在线天堂v | 最近免费中文字幕 | 丁香花在线视频观看免费 | 国产精品久久久久久久久大全 | 婷婷久久网 | 亚洲综合网站在线观看 | 国产精品av免费在线观看 | 在线免费成人 | 午夜影院先 | 激情 一区二区 | 亚洲欧美国产精品久久久久 | 国产香蕉97碰碰久久人人 | 婷婷夜夜 | 日韩中文字幕视频在线 | 日本一区二区高清不卡 | 97人人艹 | 国产精品毛片网 | 91字幕| 97超碰在线资源 | 九色精品免费永久在线 | 在线小视频 | 久久久夜色 | 久久久国产成人 | 成人午夜电影在线观看 | 色欧美成人精品a∨在线观看 | 在线看欧美 | 色婷婷激婷婷情综天天 | 亚洲综合一区二区精品导航 | 97超碰成人在线 | 黄色成年片 | 日韩精品一区二区不卡 | 黄色亚洲片 | 国产成年免费视频 | 欧美精品xxx | 啪啪免费观看网站 | 香蕉色综合 | 亚洲精品国产精品国自产在线 | 婷婷精品国产欧美精品亚洲人人爽 | 天天操天天色天天射 | 久久久免费精品国产一区二区 | 日韩xxxbbb| 国产成人精品亚洲a | 日本精品久久久久影院 | 国产美腿白丝袜足在线av | 成人一级在线 | 国产精选在线观看 | 欧美91成人网 | 精品av网站 | 国产在线免费 | 免费色视频网址 | av中文字幕在线电影 | av性网站 | 国产在线精品一区 | 中文字幕在线播放日韩 | 香蕉视频18 | 婷婷丁香综合 | 99久在线精品99re8热视频 | 狠狠狠色狠狠色综合 | 国产精品免费视频网站 | 伊人激情网 | 91欧美在线| 91色综合 | 视频二区在线视频 | 天天操夜夜想 | 国产69久久精品成人看 | 亚洲国产手机在线 | 免费看日韩片 | 国产精品久久久久毛片大屁完整版 | av大全在线免费观看 | 精品美女久久久久久免费 | 天天色视频| 亚洲二区精品 | 国产精品高潮呻吟久久av无 | 国产成人91 | 三级av黄色 | www.色婷婷.com | 日日日操操 | 国产无遮挡又黄又爽在线观看 | www国产亚洲精品久久麻豆 | 久久99精品一区二区三区三区 | 国产日韩视频在线观看 | 国产在线免费av | 狠狠色伊人亚洲综合网站色 | 激情在线网址 | 中文综合在线 | 成年人网站免费在线观看 | 国产资源免费在线观看 | 一区二区三区日韩视频在线观看 | 久久看视频 | 成人精品国产 | 日本成人黄色片 | 色噜噜日韩精品欧美一区二区 | 99久久精品久久亚洲精品 | 91禁在线观看 | 99视频精品在线 | 国产日韩精品在线观看 | 日本在线观看中文字幕 | 国产精品igao视频网网址 | 在线视频 国产 日韩 | 综合久久久久久久 | 国产精品毛片久久久久久久 | 天天草天天操 | 成人免费一级 | 一本一本久久a久久精品综合妖精 | 日韩一级片网址 | 欧美午夜精品久久久久久孕妇 | 亚洲观看黄色网 | 97国产超碰在线 | 久久天堂网站 | 精品久久网站 | 91插插影库 | 99精品毛片 | 91免费国产在线观看 | 国产一区视频导航 | 狠狠干狠狠艹 | 国产精品免费观看视频 | 91av视频免费观看 | 国产日韩在线看 | 亚洲综合在线播放 | 亚洲国产中文字幕在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 成年人看片 | 日韩经典一区二区三区 | 国产 视频 高清 免费 | 日批网站在线观看 | 久久精品三级 | 又黄又爽又刺激的视频 | 在线观看小视频 | 久久国产综合视频 | 五月天丁香 | 激情欧美一区二区免费视频 | 国产成人久久精品一区二区三区 | av动图 | 色婷婷精品大在线视频 | 激情视频国产 | 中文字幕免费一区二区 | 在线播放91 | 亚洲精品免费观看视频 | 天天插天天 | 国产精品观看 | 国产精品美女免费视频 | 色婷婷在线播放 | 国产精品成人品 | 91精品久久久久久久久 | 瑞典xxxx性hd极品 | 国产又粗又猛又色又黄网站 | 日日日操操 | 亚洲黄色免费电影 | 成人毛片一区 | 色av男人的天堂免费在线 | 国外成人在线视频网站 | 精品在线视频一区二区三区 | 免费av电影网站 | 9999国产精品| 在线国产日本 | 色婷婷电影网 | 最近最新中文字幕视频 | 精品视频在线观看 | 91高清完整版在线观看 | 国产日韩精品在线观看 | 91大神精品视频在线观看 | 一区在线免费观看 | 特级aaa毛片 | 久久日韩精品 | 日韩三区在线 | 亚洲免费在线视频 | 国产精品福利午夜在线观看 | 日本中文字幕观看 | 最近中文字幕大全 | 玖玖在线观看视频 | 国产剧情一区二区 | 精品国产1区 | 欧美日韩在线精品一区二区 | 人人射人人射 | www.夜色321.com | 日韩欧美精品在线观看视频 | 日本黄色大片儿 | 久久久国产视频 | 国产在线观看午夜 | 亚洲永久精品一区 | 少妇自拍av | 国产91欧美| 日韩在线观看a | 久草视频播放 | 亚洲国产精品视频在线观看 | 国产亚洲婷婷免费 | 日韩网站视频 | 五月婷视频 | 中文字幕一区二区三 | 国产护士hd高朝护士1 | 亚洲 欧美日韩 国产 中文 | 久久夜夜操 | 久久成人亚洲欧美电影 | 国产亚洲欧美日韩高清 | 三级在线国产 | 国产精品成人一区二区 | 亚洲国产999| 国产高清不卡一区二区三区 | 日韩精品在线播放 | 91成年人在线观看 | 日韩经典一区二区三区 | av资源免费观看 | 五月激情六月丁香 | 福利视频入口 | 日韩免费专区 | 成年人免费看片网站 | 午夜在线观看一区 | 久久精品美女视频网站 | 亚洲一区视频在线播放 | 69久久久久久久 | 夜夜爽88888免费视频4848 | 日韩大陆欧美高清视频区 | 国产精品一区二区三区免费视频 | 麻豆91精品| 国产91在线看| 国产高清在线观看 | av免费电影在线观看 | 夜夜夜草 | 韩国精品一区二区三区六区色诱 | 男女精品久久 | 91视频免费播放 | 97在线观看视频免费 | 久久亚洲成人网 | 亚洲a资源| 日韩电影在线一区 | 伊人干综合 | 亚洲精品伦理在线 | 黄色片网站大全 | 一区二区三区日韩精品 | 亚洲免费不卡 | 国产伦理一区二区 | 久久99视频精品 | 久久精品视频在线看 | av在线成人| www激情网 | 婷婷av网| 欧美日韩精品国产 | 国产精品免费在线视频 | 亚洲国产影院 | 91亚洲在线观看 | 天天做天天爱天天爽综合网 | 天天干天天插 | 亚洲黄色在线免费观看 | 婷婷五月情 | 亚洲精品91天天久久人人 | 99tvdz@gmail.com | 久久综合五月婷婷 | 久热色超碰 | 天天射天天色天天干 | 在线观看资源 | 久久爱综合 | 91天堂素人约啪 | 一区 在线 影院 | 精精国产xxxx视频在线播放 | 一区二区三区在线观看免费视频 | www.久久爱.cn | 色在线高清 | 国产91aaa | 国产精品久久久久久久久久久久 | 国产精品久一 | 黄色电影在线免费观看 | 日韩免费高清 | 91精品亚洲影视在线观看 | 福利片视频区 | 日韩精品中文字幕在线播放 | 超碰在线97免费 | 91成人观看| 天天干天天做 | 久久中文字幕导航 | 国产精品6999成人免费视频 | 综合在线亚洲 | 色91在线视频 | a级国产毛片 | 国产精品久久久久久久婷婷 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 97福利视频 | 狠狠色香婷婷久久亚洲精品 | 欧美日韩在线观看一区二区三区 | 91视频在线网址 | 日韩精品一区二区三区免费观看 | 欧美精品久久久久久久 | 国产精品av免费在线观看 | 免费在线黄色av | 久久久久亚洲精品男人的天堂 | 日韩精品一区电影 | 国产精品激情在线观看 | 五月激情亚洲 | 久久免费视频网站 | 久久视频网 | 中文字幕日韩无 | 午夜久久久久久久久久影院 | 国产精品一区二区无线 | 国产精品成人一区二区三区 | 五月天激情在线 | 亚洲精品在线电影 | 人人澡人人草 | 中文字幕在线影视资源 | 一区二区三区日韩在线 | 中文字幕在线观看第一页 | 精品久久久久久久久久久久久久久久久久 | 2022国产精品视频 | www.色国产 | 午夜性色 | 六月天色婷婷 | 色综合小说| 西西4444www大胆无视频 | 国产精品久久久久三级 | 人人爽人人爽人人爽人人爽 | 成年人在线免费看 | 色多视频在线观看 | 91麻豆视频 | 久久久亚洲精华液 | 国产成人精品电影久久久 | 中国一级特黄毛片大片久久 | 国内精品久久久久影院男同志 | 久久不卡av| 在线黄色av电影 | 美女免费视频一区 | 综合网中文字幕 | 美腿丝袜一区二区三区 | 99久久综合国产精品二区 | 香蕉久草 | 精品在线视频一区二区三区 | 国产精品视屏 | 狠狠色香婷婷久久亚洲精品 | 美腿丝袜一区二区三区 | 丁香视频全集免费观看 | 99热国内精品| 91最新视频在线观看 | 在线观看中文字幕网站 | 婷婷中文在线 | 五月天丁香视频 | 国产一级性生活视频 | 久久艹欧美| av在线播放快速免费阴 | 2021国产精品视频 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 久久免费视频播放 | 青青久视频 | 欧美久久成人 | 欧美国产日韩一区二区 | 久久大香线蕉app | 欧美一区免费在线观看 | 天天操天天干天天操天天干 | 四虎天堂 | 久久久久成 | 在线一区av | 91精品国产99久久久久久红楼 | 国产精品伦一区二区三区视频 | 久久精品伊人 | 国产在线成人 | 美女视频黄频大全免费 | 一级欧美一级日韩 | 深夜福利视频一区二区 | 黄色资源在线观看 | 日韩国产精品久久久久久亚洲 | 亚洲天天在线日亚洲洲精 | 精品久久久久久久 | 国产一区免费观看 | 在线精品视频在线观看高清 | av电影中文字幕 | 国产一区二区精品久久 | 亚洲人人av | 99在线观看精品 | 99精品欧美一区二区三区黑人哦 | 蜜臀精品久久久久久蜜臀 | 视频三区在线 | 精品国产乱码久久久久久三级人 | 国产精品亚洲综合久久 | 久久精品欧美一区 | 国产精品正在播放 | 人人插人人澡 | 99精品在线视频观看 | 日韩成片 | 国产精品99久久久久久有的能看 | 欧美一区在线观看视频 | 国产精品亚洲视频 | 日韩国产精品一区 | 久久久人人人 | 日韩啪视频 | 国产专区精品视频 | 日韩最新在线 | 日韩理论片在线观看 | 国产资源免费在线观看 | 国产午夜精品理论片在线 | 少妇性色午夜淫片aaaze | 亚洲第一区在线播放 | 中文字幕在线观看不卡 | 亚洲精品视频在线免费播放 | 色www免费视频 | 三级av免费看 | 香蕉在线播放 | 激情视频一区二区 | 国产精品一区二区果冻传媒 | 成人免费视频网站在线观看 | 久久久久久久久久免费 | 99 色| 亚洲日本va午夜在线电影 | 91中文在线视频 | 久久久久夜色 | 人人插人人草 | 国产免费激情久久 | 久草免费在线视频观看 | 在线视频91| 免费高清在线一区 | 九九日韩 | 亚洲国产播放 |