国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

一文帶你了解MySQL基于規(guī)則的優(yōu)化

 更新時(shí)間:2023年05月26日 09:16:26   作者:mutlis  
MySQL依據(jù)一些規(guī)則,竭盡全力的把這些很糟糕的語(yǔ)句轉(zhuǎn)換成某種可以比較高效執(zhí)行的形式,這個(gè)過(guò)程也可以被稱作查詢重寫,本章主要就是詳細(xì)講解下這些比較重要的重寫規(guī)則,感興趣的小伙伴可跟著小編一起來(lái)學(xué)習(xí)

一、條件簡(jiǎn)化

我們編寫的查詢語(yǔ)句的搜索條件本質(zhì)上是一個(gè)表達(dá)式,這些表達(dá)式可能比較繁雜,或者不能高效的執(zhí)行,MySQL的查詢優(yōu)化器會(huì)為我們簡(jiǎn)化這些表達(dá)式。為了方便大家理解,我們后邊舉例的時(shí)候都使用諸如ab、c之類的簡(jiǎn)單字母代表某個(gè)表的列名。

1.1 移除不必要的括號(hào)

有時(shí)候表達(dá)式里有很多無(wú)用的括號(hào),比如這樣:

((a = 5 AND b =c ) OR ((a > c) AND (c < 5)))

是不是看著就很煩,優(yōu)化器會(huì)把哪些用不到的括號(hào)都給消除,就是這樣:

(a = 5 AND b=c) OR (a > c AND c < 5)

1.2 常量傳遞(constant_propagation)

有時(shí)候像某個(gè)表達(dá)式是某個(gè)列和某個(gè)常量做等值匹配,比如這樣:

a = 5

當(dāng)這個(gè)表達(dá)式和其他涉及列a的表達(dá)式使用AND連接起來(lái)時(shí),可以將其他表達(dá)式中的a的值替換為5,比如這樣:

a = 5 AND b > a

就可以被轉(zhuǎn)換為:

a = 5 AND b > 5

小提示: 為啥用OR連接起來(lái)的表達(dá)式就不能進(jìn)行常量傳遞?自己想想哈~

1.3 等值傳遞(equality_propagation)

有時(shí)候多個(gè)列之間存在等值匹配的關(guān)系,比如這樣:

a = b AND b = c AND c = 5

這個(gè)表達(dá)式可以被簡(jiǎn)化為:

a = 5 AND b = 5 AND c = 5

1.4 移除沒(méi)用的條件(trivial_condition_removal)

對(duì)于一些明顯永遠(yuǎn)為TRUE或者FALSE的表達(dá)式,優(yōu)化器會(huì)移除掉它們,比如這個(gè)表達(dá)式:

(a < 1 AND b = b) OR (a = 6 OR 5 != 5) 

很明顯,b = b 這個(gè)表達(dá)式永遠(yuǎn)是TRUE,5 != 5 這個(gè)表達(dá)式永遠(yuǎn)是FALSE,所有簡(jiǎn)化后的表達(dá)式就是這樣的:

(a < 1 AND TRUE) OR (a = 6 OR 5 FALSE) 

可以繼續(xù)簡(jiǎn)化:

a < 1 OR a = 6 

1.5 表達(dá)式計(jì)算

在查詢開始之前,如果表達(dá)式中只包含常量的話,它的值會(huì)被先計(jì)算出來(lái),比如這個(gè):

a = 5 + 1 

因?yàn)?5 + 1 這個(gè)表達(dá)式只包含常量,所以就會(huì)簡(jiǎn)化成:

a = 6 

但是這里需要注意的是,如果某個(gè)列并不是以單獨(dú)的形式作為表達(dá)式的操作數(shù)時(shí),比如出現(xiàn)在函數(shù)中,出現(xiàn)在某個(gè)更復(fù)雜表達(dá)式中,就像這樣:

ABS(a) > 5 

或者:

-a = -8 

優(yōu)化器是不會(huì)嘗試對(duì)這些表達(dá)式進(jìn)行簡(jiǎn)化的。我們前邊說(shuō)過(guò)只有搜索條件中索引列和常數(shù)使用的某些運(yùn)算符連接起來(lái)才能使用到索引,索引如果可以的話,最好讓索引列以單獨(dú)的形式出現(xiàn)在表達(dá)式中。

1.6 HAVING子句和WHERE子句的合并

如果查詢中沒(méi)有出現(xiàn)諸如SUMMAX等的的聚集函數(shù)以及GROUP BY子句,優(yōu)化器就把HAVING子句和WHERE子句合并起來(lái)。

1.7 常量表檢測(cè)

MySQL覺(jué)得以下這兩中查詢運(yùn)行的特別快

  • 查詢表中一條記錄沒(méi)有或者只用一條記錄

小提示: 大家有沒(méi)有覺(jué)得這一條有點(diǎn)不對(duì)勁,我還沒(méi)有開始查表怎么就知道表中有幾條記錄?哈哈~這個(gè)其實(shí)依靠的是統(tǒng)計(jì)數(shù)據(jù)。不過(guò)我們說(shuō)過(guò)InnoDB的統(tǒng)計(jì)數(shù)據(jù)不準(zhǔn)確,所以這一條不能用于使用于InnoDB作為存儲(chǔ)引擎的表,只適用于使用Memory或者M(jìn)yISAM存儲(chǔ)引擎的表。

  • 使用主鍵等值匹配或者唯一二級(jí)索引列等值匹配作為搜索條件來(lái)查詢某個(gè)表

MySQL覺(jué)著這兩種查詢花費(fèi)的時(shí)間特別少,少到可以忽略,所以把通過(guò)這兩種方式查詢的表稱為常量表(英文名:constant tables)。優(yōu)化器在分析查詢一個(gè)語(yǔ)句時(shí),先首先執(zhí)行常量表的查詢,然后把查詢中涉及到該表的條件全部替換成常數(shù),最后在分析其余表的查詢成本,比方說(shuō)找個(gè)查詢語(yǔ)句:

SELECT * FROM table1 INNER JOIN table2 
    ON table1.column1 = table2.column2 
    WHERE table1.primary_key = 1;

很明顯,這個(gè)查詢可以使用主鍵和常量值的等值匹配來(lái)查詢table1表,也就是在這個(gè)查詢中table1相當(dāng)于常量表,在分析對(duì)table2表的查詢成本之前就會(huì)執(zhí)行對(duì)table1表的查詢,并把查詢中涉及table1表的條件都替換掉,也就是說(shuō)上邊的語(yǔ)句被轉(zhuǎn)換成這樣:

SELECT table1表記錄的各個(gè)字段的常量值,table2.* 
    FROM table1 INNER JOIN table2 
    ON table1.column1列的常量值 = table2.column2 ;

二、外連接消除

我們前面說(shuō)過(guò),內(nèi)連接的驅(qū)動(dòng)表和被驅(qū)動(dòng)表的位置是可以相互轉(zhuǎn)換,而左外連接右外連接的驅(qū)動(dòng)表和被驅(qū)動(dòng)表是固定的。這導(dǎo)致內(nèi)連接可能通過(guò)優(yōu)化表的連接順序來(lái)降低整體的查詢成本,而外連接卻無(wú)法優(yōu)化表的連接順序。為了我們學(xué)習(xí)的順利進(jìn)展,我們把之前介紹連接原理時(shí)用過(guò)的demo9demo10表請(qǐng)出來(lái),為了防止大家早就忘掉,我們?cè)诳匆幌逻@兩個(gè)表的結(jié)構(gòu):

mysql> create table demo9 (m1 int, n1 char(1));
Query OK, 0 rows affected (0.01 sec)
mysql> create table demo10 (m2 int, n2 char(1));
Query OK, 0 rows affected (0.03 sec)
mysql> select * from demo9;
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
|    2 | b    |
|    3 | c    |
+------+------+
3 rows in set (0.00 sec)
mysql> select * from demo10;
+------+------+
| m2   | n2   |
+------+------+
|    2 | b    |
|    3 | c    |
|    4 | d    |
+------+------+
3 rows in set (0.00 sec)

我們之前說(shuō)過(guò),外連接和內(nèi)連接的本質(zhì)就是:對(duì)于外連接驅(qū)動(dòng)表的記錄來(lái)說(shuō),如果無(wú)法在被驅(qū)動(dòng)表中找到匹配ON子句中的過(guò)濾條件的記錄,那么該記錄仍然會(huì)被加入到結(jié)果集中,對(duì)應(yīng)的被驅(qū)動(dòng)表各個(gè)字段使用NULL值填充;而內(nèi)連接的驅(qū)動(dòng)表的記錄如果無(wú)法在被驅(qū)動(dòng)表中找到匹配ON子句中的過(guò)濾條件的記錄,那么該記錄會(huì)被舍棄。查詢效果就是這樣:

mysql> SELECT * FROM demo9 INNER JOIN demo10 ON demo9.m1 = demo10.m2;
+------+------+------+------+
| m1   | n1   | m2   | n2   |
+------+------+------+------+
|    2 | b    |    2 | b    |
|    3 | c    |    3 | c    |
+------+------+------+------+
2 rows in set (0.00 sec)
mysql> SELECT * FROM demo9 LEFT  JOIN demo10 ON demo9.m1 = demo10.m2;
+------+------+------+------+
| m1   | n1   | m2   | n2   |
+------+------+------+------+
|    1 | a    | NULL | NULL |
|    2 | b    |    2 | b    |
|    3 | c    |    3 | c    |
+------+------+------+------+
3 rows in set (0.00 sec)

對(duì)于上邊例子中的左外連接來(lái)說(shuō),由于驅(qū)動(dòng)表demo9m1=1, n1='a'的記錄無(wú)法在被驅(qū)動(dòng)表demo10中找到符合ON子句條件demo9.m1 = demo10.m2的記錄,所以就直接把這條記錄加入到結(jié)果集,對(duì)應(yīng)的demo10表的m2n2列的值都設(shè)置為NULL

小提示: 左外連接和右外連接其實(shí)只在驅(qū)動(dòng)表的選取方式上是不同的,其余方面都是一樣的,所以優(yōu)化器會(huì)首先把右外連接查詢轉(zhuǎn)換成左外連接查詢。我們后邊就不再嘮叨右外連接了。

我們知道WHERE子句的殺傷力比較大,凡是不符合WHERE子句中條件的記錄都不會(huì)參與連接。只要我們?cè)谒阉鳁l件中指定關(guān)于被驅(qū)動(dòng)表相關(guān)列的值不為NULL,那么外連接中在被驅(qū)動(dòng)表中找不到符合ON子句條件的驅(qū)動(dòng)表記錄也就被排除出最后的結(jié)果集了,也就是說(shuō):在這種情況下:外連接和內(nèi)連接也就沒(méi)有什么區(qū)別了!比如說(shuō)這個(gè)查詢:

mysql> SELECT * FROM demo9 LEFT JOIN demo10 on demo9.m1 = demo10.m2 WHERE demo10.n2 IS NOT NULL;
+------+------+------+------+
| m1   | n1   | m2   | n2   |
+------+------+------+------+
|    2 | b    |    2 | b    |
|    3 | c    |    3 | c    |
+------+------+------+------+
2 rows in set (0.00 sec)

由于指定了被驅(qū)動(dòng)表demo10n2列不允許為NULL,所以上邊的demo9demo10表的左外連接查詢和內(nèi)連接查詢是一樣的。當(dāng)然,我們也可以不用顯式的指定被驅(qū)動(dòng)表的某個(gè)列IS NOT NULL,只要隱含的有這個(gè)意思就行了,比如說(shuō)這樣:

mysql> SELECT * FROM demo9 LEFT JOIN demo10 on demo9.m1 = demo10.m2 WHERE demo10.m2 = 2;
+------+------+------+------+
| m1   | n1   | m2   | n2   |
+------+------+------+------+
|    2 | b    |    2 | b    |
+------+------+------+------+
1 row in set (0.01 sec)

在這個(gè)例子中,我們?cè)?code>WHERE子句中指定了被驅(qū)動(dòng)表demo10m2列等于2,也就相當(dāng)于間接的指定了m2列不為NULL值,所以上邊的這個(gè)左外連接查詢其實(shí)和下邊這個(gè)內(nèi)連接查詢是等價(jià)的:

mysql> SELECT * FROM demo9 INNER JOIN demo10 on demo9.m1 = demo10.m2 WHERE demo10.m2 = 2;
+------+------+------+------+
| m1   | n1   | m2   | n2   |
+------+------+------+------+
|    2 | b    |    2 | b    |
+------+------+------+------+
1 row in set (0.01 sec)

我們把這種在外連接查詢中,指定的WHERE子句中包含被驅(qū)動(dòng)表中的列不為NULL值的條件稱之為空值拒絕(英文名:reject-NULL)。在被驅(qū)動(dòng)表的WHERE子句符合空值拒絕的條件后,外連接和內(nèi)連接可以相互轉(zhuǎn)換。這種轉(zhuǎn)換帶來(lái)的好處就是查詢優(yōu)化器可以通過(guò)評(píng)估表的不同連接順序的成本,選出成本最低的那種連接順序來(lái)執(zhí)行查詢。

三、子查詢優(yōu)化

我們的主題本來(lái)是嘮叨MySQL查詢優(yōu)化器是如何處理子查詢的,但是我還是擔(dān)心好多同學(xué)連接查詢的語(yǔ)法都沒(méi)掌握全,所以我們就先學(xué)習(xí)什么是個(gè)子查詢(當(dāng)然不會(huì)面面俱到啦,只是說(shuō)個(gè)大概哈~),然后再學(xué)習(xí)關(guān)于子查詢優(yōu)化的事。

3.1 子查詢語(yǔ)法

想必大家都是媽媽生下來(lái)的吧,連孫猴子都有媽媽——石頭人。懷孕媽媽肚子里的那個(gè)東東就是她的孩子,類似的,在一個(gè)查詢語(yǔ)句里的某個(gè)位置也可以有另一個(gè)查詢語(yǔ)句,這個(gè)出現(xiàn)在某個(gè)查詢語(yǔ)句的某個(gè)位置中的查詢就被稱為子查詢(我們也可以稱它為寶寶查詢哈~),那個(gè)充當(dāng)“媽媽”角色的查詢也被稱之為外層查詢。不像我們懷孕時(shí)寶寶們都只在肚子里,子查詢可以在一個(gè)外層查詢的各種位置出現(xiàn),比如:

1. SELECT 子句中

也就是我們平時(shí)說(shuō)的查詢列表,比如這樣:

mysql> SELECT (SELECT m1 FROM demo9 LIMIT 1);
+--------------------------------+
| (SELECT m1 FROM demo9 LIMIT 1) |
+--------------------------------+
|                              1 |
+--------------------------------+
1 row in set (0.01 sec)

其中的(SELECT m1 FROM demo9 LIMIT 1)就是我們嘮叨的子查詢。

2. FROM 子句中

比如:

mysql> SELECT m,n FROM (SELECT m2+1 AS m, n2 AS n FROM demo10 WHERE m2 > 1) AS t;
+------+------+
| m    | n    |
+------+------+
|    3 | b    |
|    4 | c    |
|    5 | d    |
+------+------+
3 rows in set (0.00 sec)

這個(gè)例子中的子查詢是:(SELECT m2 + 1 AS m, n2 AS n FROM demo10 WHERE m2 > 1),很特別的地方是它出現(xiàn)在了FROM子句中。FROM子句這邊不是存放我們要查詢的表的名稱么,這里放進(jìn)來(lái)一個(gè)子查詢是個(gè)什么鬼?其實(shí)這里我們可以把子查詢的查詢結(jié)果當(dāng)作是一個(gè)表,子查詢后邊的AS t表明這個(gè)子查詢的結(jié)果就相當(dāng)于一個(gè)名稱為t的表,這個(gè)名叫t的表的列就是子查詢結(jié)果中的列,比如例子中表 t 就有兩個(gè)列:m 列和 n 列。這個(gè)放在FROM子句中的子查詢本質(zhì)上相當(dāng)于一個(gè)表,但是和我們平常使用的表有點(diǎn)不一樣,MySQL把這種由子查詢結(jié)果集組成的表稱之為派生表

3. WHERE或ON 子句中

把子查詢放在外層查詢的WHERE子句或者ON子句中可能是我們最常用的一種使用子查詢的方式了,比如這樣:

mysql> SELECT * FROM demo9 WHERE m1 IN (SELECT m2 FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
|    3 | c    |
+------+------+
2 rows in set (0.00 sec)

這個(gè)查詢表明我們想要將(SELECT m2 FROM demo10)這個(gè)子查詢的結(jié)果作為外層查詢的IN語(yǔ)句參數(shù),整個(gè)查詢語(yǔ)句的意思就是我們想找demo9表中的某些記錄,這些記錄的m1列的值能在demo10表的m2列找到匹配的值。

4. ORDER BY和GROUP BY 子句中

雖然語(yǔ)法支持,但沒(méi)啥子意義,不嘮叨這種情況了

3.1.1 按返回的結(jié)果集區(qū)分子查詢

因?yàn)樽硬樵儽旧硪菜闶且粋€(gè)查詢,所以可以按照它們返回的不同結(jié)果集類型而把這些子查詢分為不同的類型:

1. 標(biāo)量子查詢

那些只返回一個(gè)單一值的子查詢稱之為標(biāo)量子查詢,比如這樣:

mysql> SELECT (SELECT m1 FROM demo9 LIMIT 1);
+--------------------------------+
| (SELECT m1 FROM demo9 LIMIT 1) |
+--------------------------------+
|                              1 |
+--------------------------------+
1 row in set (0.00 sec)

或者這樣:

mysql> SELECT * FROM demo9 WHERE m1 = (SELECT MIN(m2) FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

這兩個(gè)查詢語(yǔ)句中的子查詢都返回一個(gè)單一的值,也就是一個(gè)標(biāo)量。這些標(biāo)量子查詢可以作為一個(gè)單一值或者表達(dá)式的一部分出現(xiàn)在查詢語(yǔ)句的各個(gè)地方。

2. 行子查詢

顧名思義,就是返回一條記錄的子查詢,不過(guò)這條記錄需要包含多個(gè)列(只包含一個(gè)列就成了標(biāo)量子查詢了)。比如這樣:

mysql> SELECT * FROM demo9 WHERE (m1, n1) = (SELECT m2, n2 FROM demo10 LIMIT 1);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

其中的(SELECT m2, n2 FROM demo10 LIMIT 1)就是一個(gè)行子查詢,整條語(yǔ)句的含義就是要從demo9表中找一些記錄,這些記錄的m1n1列分別等于子查詢結(jié)果中的m2n2列。

3. 列子查詢

列子查詢自然就是查詢出一個(gè)列的數(shù)據(jù)嘍,不過(guò)這個(gè)列的數(shù)據(jù)需要包含多條記錄(只包含一條記錄就成了標(biāo)量子查詢了)。比如這樣:

mysql> SELECT * FROM demo9 WHERE m1 IN (SELECT m2 FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
|    3 | c    |
+------+------+
2 rows in set (0.00 sec)

其中的(SELECT m2 FROM demo10)就是一個(gè)列子查詢,表明查詢出demo10表的m2列的值作為外層查詢IN語(yǔ)句的參數(shù)。

4. 表子查詢

顧名思義,就是子查詢的結(jié)果既包含很多條記錄,又包含很多個(gè)列,比如這樣:

mysql> SELECT * FROM demo9 WHERE (m1, n1) IN (SELECT m2, n2 FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
|    3 | c    |
+------+------+
2 rows in set (0.00 sec)

其中的(SELECT m2, n2 FROM demo10)就是一個(gè)表子查詢,這里需要和行子查詢對(duì)比一下,行子查詢中我們用了LIMIT 1來(lái)保證子查詢的結(jié)果只有一條記錄,表子查詢中不需要這個(gè)限制。

3.1.2 按與外層查詢關(guān)系來(lái)區(qū)分子查詢

1. 不相關(guān)子查詢

如果子查詢可以單獨(dú)運(yùn)行出結(jié)果,而不依賴于外層查詢的值,我們就可以把這個(gè)子查詢稱之為不相關(guān)子查詢。我們前邊介紹的那些子查詢?nèi)慷伎梢钥醋鞑幌嚓P(guān)子查詢,所以也就不舉例子了哈~

2. 相關(guān)子查詢

如果子查詢的執(zhí)行需要依賴于外層查詢的值,我們就可以把這個(gè)子查詢稱之為相關(guān)子查詢。比如:

mysql> SELECT * FROM demo9 WHERE m1 IN (SELECT m2 FROM demo10 WHERE n1 = n2);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
|    3 | c    |
+------+------+
2 rows in set (0.00 sec)

例子中的子查詢是(SELECT m2 FROM demo10 WHERE n1 = n2),可是這個(gè)查詢中有一個(gè)搜索條件是n1 = n2,別忘了n1是表demo9的列,也就是外層查詢的列,也就是說(shuō)子查詢的執(zhí)行需要依賴于外層查詢的值,所以這個(gè)子查詢就是一個(gè)相關(guān)子查詢。

3.1.3 子查詢?cè)诓紶柋磉_(dá)式中的使用

你說(shuō)寫下邊這樣的子查詢有啥意義:

SELECT (SELECT m1 FROM demo9 LIMIT 1);

貌似沒(méi)啥意義~ 我們平時(shí)用子查詢最多的地方就是把它作為布爾表達(dá)式的一部分來(lái)作為搜索條件用在WHERE子句或者ON子句里。所以我們這里來(lái)總結(jié)一下子查詢?cè)诓紶柋磉_(dá)式中的使用場(chǎng)景

1. 使用=、>、<、>=、<=、<>、!=、<=>作為布爾表達(dá)式的操作符

這些操作符具體是啥意思就不用我多介紹了吧,如果你不知道的話,那我真的很佩服你是靠著啥勇氣一口看到這里的~ 為了方便,我們就把這些操作符稱為comparison_operator吧,所以子查詢組成的布爾表達(dá)式就長(zhǎng)這樣:

操作數(shù) comparison_operator (子查詢)

這里的操作數(shù)可以是某個(gè)列名,或者是一個(gè)常量,或者是一個(gè)更復(fù)雜的表達(dá)式,甚至可以是另一個(gè)子查詢。但是需要注意的是,這里的子查詢只能是標(biāo)量子查詢或者行子查詢,也就是子查詢的結(jié)果只能返回一個(gè)單一的值或者只能是一條記錄。

比如這樣(標(biāo)量子查詢):

mysql> SELECT * FROM demo9 WHERE m1 < (SELECT MIN(m2) FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
+------+------+
1 row in set (0.00 sec)

或者這樣(行子查詢):

mysql> SELECT * FROM demo9 WHERE (m1, n1) = (SELECT m2, n2 FROM demo10 LIMIT 1);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
+------+------+
1 row in set (0.00 sec)

2. [NOT] IN/ANY/SOME/ALL子查詢

對(duì)于列子查詢和表子查詢來(lái)說(shuō),它們的結(jié)果集中包含很多條記錄,這些記錄相當(dāng)于是一個(gè)集合,所以就不能單純的和另外一個(gè)操作數(shù)使用comparison_operator來(lái)組成布爾表達(dá)式了,MySQL通過(guò)下列的語(yǔ)法來(lái)支持某個(gè)操作數(shù)和一個(gè)集合組成一個(gè)布爾表達(dá)式:

a. IN或者NOT IN

具體的語(yǔ)法形式如下:操作數(shù) [NOT] IN (子查詢)

這個(gè)布爾表達(dá)式的意思是用來(lái)判斷某個(gè)操作數(shù)在不在由子查詢結(jié)果集組成的集合中,比如下邊的查詢的意思是找出demo9表中的某些記錄,這些記錄存在于子查詢的結(jié)果集中:

mysql> SELECT * FROM demo9 WHERE (m1, n1) IN (SELECT m2, n2 FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    2 | b    |
|    3 | c    |
+------+------+
2 rows in set (0.00 sec)

b. ANY/SOME(ANY和SOME是同義詞) 具體的語(yǔ)法形式如下:操作數(shù) comparison_operator ANY/SOME(子查詢)

這個(gè)布爾表達(dá)式的意思是只要子查詢結(jié)果集中存在某個(gè)值和給定的操作數(shù)做comparison_operator比較結(jié)果為TRUE,那么整個(gè)表達(dá)式的結(jié)果就為TRUE,否則整個(gè)表達(dá)式的結(jié)果就為FALSE。比如說(shuō)下邊這個(gè)查詢:

mysql> SELECT * FROM demo9 WHERE m1 > ANY(SELECT m2 FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.00 sec)

這個(gè)查詢的意思就是對(duì)于demo9表的某條記錄的m1列的值來(lái)說(shuō),如果子查詢(SELECT m2 FROM demo10)的結(jié)果集中存在一個(gè)小于m1列的值,那么整個(gè)布爾表達(dá)式的值就是TRUE,否則為FALSE,也就是說(shuō)只要m1列的值大于子查詢結(jié)果集中最小的值,整個(gè)表達(dá)式的結(jié)果就是TRUE,所以上邊的查詢本質(zhì)上等價(jià)于這個(gè)查詢:

mysql> SELECT * FROM demo9 WHERE m1 > (SELECT MIN(m2) FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    3 | c    |
+------+------+
1 row in set (0.01 sec)

另外,=ANY相當(dāng)于判斷子查詢結(jié)果集中是否存在某個(gè)值和給定的操作數(shù)相等,它的含義和IN是相同的

c. ALL

具體的語(yǔ)法形式如下:操作數(shù) comparison_operator ALL(子查詢)

這個(gè)布爾表達(dá)式的意思是子查詢結(jié)果集中所有的值和給定的操作數(shù)做comparison_operator比較結(jié)果為TRUE,那么整個(gè)表達(dá)式的結(jié)果就為TRUE,否則整個(gè)表達(dá)式的結(jié)果就為FALSE。比如說(shuō)下邊這個(gè)查詢:

mysql> SELECT * FROM demo9 WHERE m1 > ALL(SELECT m2 FROM demo10);
Empty set (0.00 sec)

這個(gè)查詢的意思就是對(duì)于demo9表的某條記錄的m1列的值來(lái)說(shuō),如果子查詢(SELECT m2 FROM demo10)的結(jié)果集中的所有值都大于m1列的值,那么整個(gè)布爾表達(dá)式的值就是TRUE,否則為FALSE,也就是說(shuō)只要m1列的值大于子查詢結(jié)果集中最小的值,整個(gè)表達(dá)式的結(jié)果就是TRUE,所以上邊的查詢本質(zhì)上等價(jià)于這個(gè)查詢:

mysql> SELECT * FROM demo9 WHERE m1 > (SELECT MAX(m2) FROM demo10);
Empty set (0.00 sec)

d. EXISTS子查詢

有的時(shí)候我們僅僅需要判斷子查詢的結(jié)果集中是否有記錄,而不在乎它的記錄具體是個(gè)啥,可以使用把EXISTS或者NOT EXISTS放在子查詢語(yǔ)句前邊,就像這樣:[NOT] EXISTS (子查詢)

我們舉一個(gè)例子?。?/p>

mysql> SELECT * FROM demo9 WHERE EXISTS (SELECT 1 FROM demo10);
+------+------+
| m1   | n1   |
+------+------+
|    1 | a    |
|    2 | b    |
|    3 | c    |
+------+------+
3 rows in set (0.00 sec)

對(duì)于子查詢(SELECT 1 FROM demo10)來(lái)說(shuō),我們并不關(guān)心這個(gè)子查詢最后到底查詢出的結(jié)果是什么,所以查詢列表里填*、某個(gè)列名,或者其他啥東系都無(wú)所謂,我們真正關(guān)心的是子查詢的結(jié)果集中是否存在記錄。也就是說(shuō)只要(SELECT 1 FROM demo10)這個(gè)查詢中有記錄,那么整個(gè)EXISTS表達(dá)式的結(jié)果就為TRUE

3.1.4 子查詢語(yǔ)法注意事項(xiàng)

1. 子查詢必須使用括號(hào)擴(kuò)起來(lái)

不擴(kuò)起來(lái)的子查詢是非法的,比如這樣:

mysql> SELECT SELECT m1 FROM demo9;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your
MySQL server version for the right syntax to use near 'SELECT m1 FROM demo9' at line 1

2. 在SELECT子句中的子查詢必須是標(biāo)量子查詢

如果子查詢結(jié)果集中有多個(gè)列或者多個(gè)行,都不允許放在SELECT子句中,也就是查詢列表中,比如這樣就是非法的:

mysql> SELECT (SELECT m1, n1 FROM demo9);
ERROR 1241 (21000): Operand should contain 1 column(s)

3. 在想要得到標(biāo)量子查詢或者行子查詢,但又不能保證子查詢的結(jié)果集只有一條記錄時(shí),應(yīng)該使用LIMIT 1語(yǔ)句來(lái)限制記錄數(shù)量。

4. 對(duì)于[NOT] IN/ANY/SOME/ALL子查詢來(lái)說(shuō),子查詢中不允許有LIMIT語(yǔ)句

比如這樣是非法的:

mysql> SELECT * FROM demo9 WHERE m1 IN (SELECT * FROM demo10 LIMIT 2);
ERROR 1235 (42000): This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'

為啥不合法?人家就這么規(guī)定的,不解釋~ 可能以后的版本會(huì)支持吧。正因?yàn)?code>[NOT] IN/ANY/SOME/ALL子查詢不支持LIMIT語(yǔ)句,所以子查詢中的這些語(yǔ)句也就是多余的了

5. ORDER BY子句

子查詢的結(jié)果其實(shí)就相當(dāng)于一個(gè)集合,集合里的值排不排序一點(diǎn)都不重要,比如下邊這個(gè)語(yǔ)句中的ORDER BY子句簡(jiǎn)直就是畫蛇添足:

SELECT * FROM demo9 WHERE m1 IN (SELECT m2 FROM demo10 ORDER BY m2);

6. DISTINCT語(yǔ)句

集合里的值去不去重也沒(méi)啥意義,比如這樣:

SELECT * FROM demo9 WHERE m1 IN (SELECT DISTINCT m2 FROM demo10);

7. 沒(méi)有聚集函數(shù)以及HAVING子句的GROUP BY子句

在沒(méi)有聚集函數(shù)以及HAVING子句時(shí),GROUP BY子句就是個(gè)擺設(shè),比如這樣:

SELECT * FROM demo9 WHERE m1 IN (SELECT m2 FROM demo10 GROUP BY m2);

對(duì)于這些冗余的語(yǔ)句,查詢優(yōu)化器在一開始就把它們給干掉了。

8. 不允許在一條語(yǔ)句中增刪改某個(gè)表的記錄時(shí)同時(shí)還對(duì)該表進(jìn)行子查詢

比方說(shuō)這樣:

mysql> DELETE FROM demo9 WHERE m1 < (SELECT MAX(m1) FROM demo9);
ERROR 1093 (HY000): You can't specify target table 'demo9' for update in FROM clause

3.2 子查詢?cè)贛ySQL中是怎么執(zhí)行的

好了,關(guān)于子查詢的基礎(chǔ)語(yǔ)法我們用最快的速度溫習(xí)了一遍,如果想了解更多語(yǔ)法細(xì)節(jié),大家可以去查看一下MySQL的文檔哈~現(xiàn)在我們就假設(shè)各位都懂了啥是個(gè)子查詢了喔,接下來(lái)就要嘮叨具體某種類型的子查詢?cè)贛ySQL中是怎么執(zhí)行的了,想想是不是就有一點(diǎn)激動(dòng)~ 當(dāng)然,為了故事的順利發(fā)展,我們的例子也需要跟隨形勢(shì)換槍換炮,還是要祭出我們?cè)谝晃膸懔私釳ySQL之基于成本的優(yōu)化文章中用到的s1表和s2

mysql> create table s1 (    
id int not null auto_increment,    
key1 varchar(100),    
key2 int,    
key3 varchar(100),    
key_part1 varchar(100),    
key_part2 varchar(100),    
key_part3 varchar(100),    
common_field varchar(100), 
primary key (id),
key idx_key1 (key1),    
unique key idx_key2 (key2),    
key idx_key3 (key3),    
key idx_key_part(key_part1, key_part2, key_part3));
Query OK, 0 rows affected (0.04 sec)
mysql> create table s2 (    
id int not null auto_increment,    
key1 varchar(100),    
key2 int,    
key3 varchar(100),    
key_part1 varchar(100),    
key_part2 varchar(100),    
key_part3 varchar(100),    
common_field varchar(100), 
primary key (id),
key idx_key1 (key1),    
unique key idx_key2 (key2),    
key idx_key3 (key3),    
key idx_key_part(key_part1, key_part2, key_part3));
Query OK, 0 rows affected (0.04 sec)
mysql> insert into s1 select * from demo8;
Query OK, 20000 rows affected (0.83 sec)
Records: 20000  Duplicates: 0  Warnings: 0
mysql> insert into s2 select * from demo8;
Query OK, 20000 rows affected (0.89 sec)
Records: 20000  Duplicates: 0  Warnings: 0

這兩個(gè)表s1、s2的構(gòu)造是相同的,并且這兩個(gè)表里邊都有20000條記錄,除id列外其余的列都插入隨機(jī)值。下邊正式開始我們的表演。

3.2.1 小白們眼中子查詢的執(zhí)行方式

在我還是一個(gè)單純無(wú)知的少年時(shí),覺(jué)得子查詢的執(zhí)行方式是這樣的:

  • 如果該子查詢是不相關(guān)子查詢,比如下邊這個(gè)查詢:SELECT * FROM s1WHERE key1 IN (SELECT common_field FROM s2)

    我年少時(shí)覺(jué)得這個(gè)查詢是的執(zhí)行方式是這樣的:

    • 先單獨(dú)執(zhí)行(SELECT common_field FROM s2)這個(gè)子查詢
    • 然后在將上一步子查詢得到的結(jié)果當(dāng)作外層查詢的參數(shù)再執(zhí)行外層查詢SELECT * FROM s1 WHERE key1 IN (...)。
  • 如果該子查詢是相關(guān)子查詢,比如下邊這個(gè)查詢:SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE s1.key2 = s2.key2)

    這個(gè)查詢中的子查詢中出現(xiàn)了s1.key2 = s2.key2這樣的條件,意味著該子查詢的執(zhí)行依賴著外層查詢的值,所以我年少時(shí)覺(jué)得這個(gè)查詢的執(zhí)行方式是這樣的:

    • 先從外層查詢中獲取一條記錄,本例中也就是先從s1表中獲取一條記錄
    • 然后從上一步驟中獲取的那條記錄中找出子查詢中涉及到的值,本例中就是從s1表中獲取的那條記錄中找出s1.key2列的值,然后執(zhí)行子查詢
    • 最后根據(jù)子查詢的查詢結(jié)果來(lái)檢測(cè)外層查詢WHERE子句的條件是否成立,如果成立,就把外層查詢的那條記錄加入到結(jié)果集,否則就丟棄
    • 再次執(zhí)行第一步,獲取第二條外層查詢中的記錄,依次類推~

不要告訴我只是一個(gè)人是這樣認(rèn)為的~

其實(shí)MySQL想了一系列的辦法來(lái)優(yōu)化子查詢的執(zhí)行,大部分情況下這些優(yōu)化措施其實(shí)挺有效的,但是保不齊有的時(shí)候馬失前蹄,下邊我們?cè)敿?xì)嘮叨各種不同類型的子查詢具體是怎么執(zhí)行的。

3.2.2 標(biāo)量子查詢、行子查詢的執(zhí)行方式

我們經(jīng)常在下邊兩個(gè)場(chǎng)景中使用到標(biāo)量子查詢或者行子查詢:

  • SELECT子句中,我們前邊說(shuō)過(guò)的在查詢列表中的子查詢必須是標(biāo)量子查詢
  • 子查詢使用=、>、<、>=、<=、<>、!=、<=>等操作符和某個(gè)操作數(shù)組成一個(gè)布爾表達(dá)式,這樣的子查詢必須是標(biāo)量子查詢或者行子查詢。

對(duì)于上述兩種場(chǎng)景中的不相關(guān)注意是不相關(guān)不相關(guān)不相關(guān))標(biāo)量子查詢或者行子查詢來(lái)說(shuō),它們的執(zhí)行方式是簡(jiǎn)單的,比如說(shuō)下邊這個(gè)查詢語(yǔ)句:

SELECT * FROM s1 WHERE key1 = (SELECT common_field FROM s2 WHERE key3 = 'a' LIMIT 1);

它的執(zhí)行方式和年少的我想的一樣:

  • 先單獨(dú)執(zhí)行(SELECT common_field FROM s2 WHERE key3 = 'a' LIMIT 1)這個(gè)子查詢
  • 然后在將上一步子查詢得到的結(jié)果當(dāng)作外層查詢的參數(shù)再執(zhí)行外層查詢SELECT * FROM s1 WHERE key1 = ...

也就是說(shuō),對(duì)于包含不相關(guān)的標(biāo)量子查詢或者行子查詢的查詢語(yǔ)句來(lái)說(shuō),MySQL會(huì)分別獨(dú)立的執(zhí)行外層查詢和子查詢,就當(dāng)作兩個(gè)單表查詢就好了。

對(duì)于相關(guān)的標(biāo)量子查詢或者行子查詢來(lái)說(shuō),比如下邊這個(gè)查詢:

SELECT * FROM s1 WHERE key1 = (SELECT common_field FROM s2 WHERE s1.key3 = s2.key3 LIMIT 1);

事情也和年少的我想的一樣,它的執(zhí)行方式就是這樣的:

  • 先從外層查詢中獲取一條記錄,本例中也就是先從s1表中獲取一條記錄
  • 然后從上一步驟中獲取的那條記錄中找出子查詢中涉及到的值,本例中就是從s1表中獲取的那條記錄中找出s1.key3列的值,然后執(zhí)行子查詢
  • 最后根據(jù)子查詢的查詢結(jié)果來(lái)檢測(cè)外層查詢WHERE子句的條件是否成立,如果成立,就把外層查詢的那條記錄加入到結(jié)果集,否則就丟棄。 再次執(zhí)行第一步,獲取第二條外層查詢中的記錄,依次類推~

也就是說(shuō)對(duì)于一開始嘮叨的兩種使用標(biāo)量子查詢以及行子查詢的場(chǎng)景中,MySQL優(yōu)化器的執(zhí)行方式并沒(méi)有什么新鮮的。

3.3 IN子查詢優(yōu)化

3.3.1 物化表的提出

對(duì)于不相關(guān)的IN子查詢,比如這樣:

SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a');

我們最開始的感覺(jué)就是這種不相關(guān)的IN子查詢和不相關(guān)的標(biāo)量子查詢或者行子查詢是一樣一樣的,都是把外層查詢和子查詢當(dāng)作兩個(gè)獨(dú)立的單表查詢來(lái)對(duì)待,可是很遺憾的是MySQL為了優(yōu)化IN子查詢傾注了太多心血(畢竟IN子查詢是我們?nèi)丈钪凶畛S玫淖硬樵冾愋停哉麄€(gè)執(zhí)行過(guò)程并不像我們想象的那么簡(jiǎn)單~

其實(shí)說(shuō)句老實(shí)話,對(duì)于不相關(guān)的IN子查詢來(lái)說(shuō),如果子查詢的結(jié)果集中的記錄條數(shù)很少,那么把子查詢和外層查詢分別看成兩個(gè)單獨(dú)的單表查詢效率還是蠻高的,但是如果單獨(dú)執(zhí)行子查詢后的結(jié)果集太多的話,就會(huì)導(dǎo)致這些問(wèn)題:

  • 結(jié)果集太多,可能內(nèi)存中都放不下~
  • 對(duì)于外層查詢來(lái)說(shuō),如果子查詢的結(jié)果集太多,那就意味著IN子句中的參數(shù)特別多,這就導(dǎo)致:
    • 無(wú)法有效的使用索引,只能對(duì)外層查詢進(jìn)行全表掃描

    • 在對(duì)外層查詢執(zhí)行全表掃描時(shí),由于IN子句中的參數(shù)太多,這會(huì)導(dǎo)致檢測(cè)一條記錄是否符合和IN子句中的參數(shù)匹配花費(fèi)的時(shí)間太長(zhǎng),比如說(shuō)IN子句中的參數(shù)只有兩個(gè):SELECT * FROM tbl_name WHERE column IN (a, b)

      這樣相當(dāng)于需要對(duì)tbl_name表中的每條記錄判斷一下它的column列是否符合column = a OR column = b。在IN子句中的參數(shù)比較少時(shí)這并不是什么問(wèn)題,如果IN子句中的參數(shù)比較多時(shí),比如這樣:SELECT * FROM tbl_name WHERE column IN (a, b, c ..., ...)

      那么這樣每條記錄需要判斷一下它的column列是否符合column = a OR column = b OR column = c OR ...,這樣性能耗費(fèi)可就多了。

于是MySQL想了一個(gè)招:不直接將不相關(guān)子查詢的結(jié)果集當(dāng)作外層查詢的參數(shù),而是將該結(jié)果集寫入一個(gè)臨時(shí)表里。寫入臨時(shí)表的過(guò)程是這樣的:

  • 該臨時(shí)表的列就是子查詢結(jié)果集中的列

  • 寫入臨時(shí)表的記錄會(huì)被去重

    我們說(shuō)IN語(yǔ)句是判斷某個(gè)操作數(shù)在不在某個(gè)集合中,集合中的值重不重復(fù)對(duì)整個(gè)IN語(yǔ)句的結(jié)果并沒(méi)有啥子關(guān)系,所以我們?cè)趯⒔Y(jié)果集寫入臨時(shí)表時(shí)對(duì)記錄進(jìn)行去重可以讓臨時(shí)表變得更小,更省地方~

    小提示: 臨時(shí)表如何對(duì)記錄進(jìn)行去重?這不是小意思嘛,臨時(shí)表也是個(gè)表,只要為表中記錄的所有列建立主鍵或者唯一索引就好了嘛~

  • 一般情況下子查詢結(jié)果集不會(huì)大的離譜,所以會(huì)為它建立基于內(nèi)存的使用Memory存儲(chǔ)引擎的臨時(shí)表,而且會(huì)為該表建立哈希索引。

    小提示: IN語(yǔ)句的本質(zhì)就是判斷某個(gè)操作數(shù)在不在某個(gè)集合里,如果集合中的數(shù)據(jù)建立了哈希索引,那么這個(gè)匹配的過(guò)程就是超級(jí)快的。 有同學(xué)不知道哈希索引是什么?我這里就不展開了,自己上網(wǎng)找找吧,不會(huì)了再來(lái)問(wèn)我~

    如果子查詢的結(jié)果集非常大,超過(guò)了系統(tǒng)變量tmp_table_size或者max_heap_table_size,臨時(shí)表會(huì)轉(zhuǎn)而使用基于磁盤的存儲(chǔ)引擎來(lái)保存結(jié)果集中的記錄,索引類型也對(duì)應(yīng)轉(zhuǎn)變?yōu)锽+樹索引。

MySQL的把這個(gè)將子查詢結(jié)果集中的記錄保存到臨時(shí)表的過(guò)程稱之為物化(英文名:Materialize)。為了方便起見,我們就把那個(gè)存儲(chǔ)子查詢結(jié)果集的臨時(shí)表稱之為物化表。正因?yàn)槲锘碇械挠涗浂冀⒘怂饕ɑ趦?nèi)存的物化表有哈希索引,基于磁盤的有B+樹索引),通過(guò)索引執(zhí)行IN語(yǔ)句判斷某個(gè)操作數(shù)在不在子查詢結(jié)果集中變得???欤瑥亩嵘俗硬樵冋Z(yǔ)句的性能。

3.3.2 物化表轉(zhuǎn)連接

事情到這就完了?我們還得重新審視一下最開始的那個(gè)查詢語(yǔ)句:

SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a');

當(dāng)我們把子查詢進(jìn)行物化之后,假設(shè)子查詢物化表的名稱為materialized_table,該物化表存儲(chǔ)的子查詢結(jié)果集的列為m_val,那么這個(gè)查詢其實(shí)可以從下邊兩種角度來(lái)看待:

  • 從表s1的角度來(lái)看待,整個(gè)查詢的意思其實(shí)是:對(duì)于s1表中的每條記錄來(lái)說(shuō),如果該記錄的key1列的值在子查詢對(duì)應(yīng)的物化表中,則該記錄會(huì)被加入最終的結(jié)果集。畫個(gè)圖表示一下就是這樣:

  • 從子查詢物化表的角度來(lái)看待,整個(gè)查詢的意思其實(shí)是:對(duì)于子查詢物化表的每個(gè)值來(lái)說(shuō),如果能在s1表中找到對(duì)應(yīng)的key1列的值與該值相等的記錄,那么就把這些記錄加入到最終的結(jié)果集。畫個(gè)圖表示如下就是這樣:

也就是說(shuō)其實(shí)上邊的查詢就相當(dāng)于表s1和子查詢物化表materialized_table進(jìn)行內(nèi)連接:

SELECT s1.* FROM s1 INNER JOIN materialized_table ON key1 = m_val;

轉(zhuǎn)化成內(nèi)連接之后就有意思了,查詢優(yōu)化器可以評(píng)估不同連接順序需要的成本是多少,選取成本最低的那種查詢方式執(zhí)行查詢。我們分析一下上述查詢中使用外層查詢的s1表和物化表materialized_table進(jìn)行內(nèi)連接的成本都是由哪幾部分組成的:

  • 如果使用s1表作為驅(qū)動(dòng)表的話,總查詢成本由下邊幾個(gè)部分組成:

    • 物化子查詢時(shí)需要的成本
    • 掃描s1表時(shí)的成本
    • s1表中的記錄數(shù)量 × 通過(guò)m_val = xxx對(duì)materialized_table表進(jìn)行單表訪問(wèn)的成本(我們前邊說(shuō)過(guò)物化表中的記錄是不重復(fù)的,并且為物化表中的列建里了索引,所以這個(gè)步驟顯然是非常快的)
  • 如果使用materialized_table表作為驅(qū)動(dòng)表的話,總查詢成本由下邊幾個(gè)部分組成:

    • 物化子查詢時(shí)需要的成本
    • 掃描物化表時(shí)的成本
    • 物化表中的記錄數(shù)量 × 通過(guò)key1 = xxx對(duì)s1表進(jìn)行單表訪問(wèn)的成本(非常慶幸key1列上建立了索引,所以這個(gè)步驟是非??斓模?/li>

MySQL查詢優(yōu)化器會(huì)通過(guò)運(yùn)算來(lái)選擇上述成本更低的方案來(lái)執(zhí)行查詢

3.3.3 將子查詢轉(zhuǎn)換為semi-join

雖然將子查詢進(jìn)行物化之后再執(zhí)行查詢都會(huì)有建立臨時(shí)表的成本,但是不管怎么說(shuō),我們見識(shí)到了將子查詢轉(zhuǎn)換為連接的強(qiáng)大作用,MySQL繼續(xù)開腦洞:能不能不進(jìn)行物化操作直接把子查詢轉(zhuǎn)換為連接呢?讓我們重新審視一下上邊的查詢語(yǔ)句:

SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a');

我們可以把這個(gè)查詢理解成:對(duì)于s1表中的某條記錄,如果我們能在s2表(準(zhǔn)確的說(shuō)是執(zhí)行完WHERE s2.key3 = 'a'之后的結(jié)果集)中找到一條或多條記錄,這些記錄的common_field的值等于s1表記錄的key1列的值,那么該條s1表的記錄就會(huì)被加入到最終的結(jié)果集。這個(gè)過(guò)程其實(shí)和把s1s2兩個(gè)表連接起來(lái)的效果很像:

SELECT s1.* FROM s1 INNER JOIN s2 ON s1.key1 = s2.common_field WHERE s2.key3 = 'a';

只不過(guò)我們不能保證對(duì)于s1表的某條記錄來(lái)說(shuō),在s2表(準(zhǔn)確的說(shuō)是執(zhí)行完WHERE s2.key3 = 'a'之后的結(jié)果集)中有多少條記錄滿足s1.key1 =s2.common_field這個(gè)條件,不過(guò)我們可以分三種情況討論:

  • 情況一:對(duì)于s1表的某條記錄來(lái)說(shuō),s2表中沒(méi)有任何記錄滿足s1.key1 = s2.common_field這個(gè)條件,那么該記錄自然也不會(huì)加入到最后的結(jié)果集
  • 情況二:對(duì)于s1表的某條記錄來(lái)說(shuō),s2表中有且只有記錄滿足s1.key1 = s2.common_field這個(gè)條件,那么該記錄會(huì)被加入最終的結(jié)果集
  • 情況三:對(duì)于s1表的某條記錄來(lái)說(shuō),s2表中至少有2條記錄滿足s1.key1 = s2.common_field這個(gè)條件,那么該記錄會(huì)被多次加入最終的結(jié)果集

對(duì)于s1表的某條記錄來(lái)說(shuō),由于我們只關(guān)心s2表中是否存在記錄滿足s1.key1 = s2.common_field這個(gè)條件,而不關(guān)心具體有多少條記錄與之匹配,又因?yàn)橛?code>情況三的存在,我們上邊所說(shuō)的IN子查詢和兩表連接之間并不完全等價(jià)。但是將子查詢轉(zhuǎn)換為連接又真的可以充分發(fā)揮優(yōu)化器的作用,所以MySQL在這里提出了一個(gè)新概念 --- 半連接(英文名:semi-join)。將s1表和s2表進(jìn)行半連接的意思就是:對(duì)于s1表的某條記錄來(lái)說(shuō),我們只關(guān)心在s2表中是否存在與之匹配的記錄是否存在,而不關(guān)心具體有多少條記錄與之匹配,最終的結(jié)果集中只保留s1表的記錄。為了讓大家有更直觀的感受,我們假設(shè)MySQL內(nèi)部是這么改寫上邊的子查詢的:

SELECT s1.* FROM s1 SEMI JOIN s2 ON s1.key1 = s2.common_field WHERE key3 = 'a';

小提示: semi-join只是在MySQL內(nèi)部采用的一種執(zhí)行子查詢的方式,MySQL并沒(méi)有提供面向用戶的semi-join語(yǔ)法,所以我們不需要,也不能嘗試把上邊這個(gè)語(yǔ)句放到黑框框里運(yùn)行,我只是想說(shuō)明一下上邊的子查詢?cè)贛ySQL內(nèi)部會(huì)被轉(zhuǎn)換為類似上邊語(yǔ)句的半連接~

概念是有了,怎么實(shí)現(xiàn)這種所謂的半連接呢?MySQL準(zhǔn)備了好幾種辦法

1. Table pullout (子查詢中的表上拉)

當(dāng)子查詢的查詢列表處只有主鍵或者唯一索引列時(shí),可以直接把子查詢中的表上拉到外層查詢的FROM子句中,并把子查詢中的搜索條件合并到外層查詢的搜索條件中,比如這個(gè):

SELECT * FROM s1 WHERE key2 IN (SELECT key2 FROM s2 WHERE key3 = 'a');

由于key2列是s2表的唯一二級(jí)索引列,所以我們可以直接把s2表上拉到外層查詢的FROM子句中,并且把子查詢中的搜索條件合并到外層查詢的搜索條件中,上拉之后的查詢就是這樣的:

SELECT s1.* FROM s1 INNER JOIN s2 ON s1.key2 = s2.key2 WHERE s2.key3 = 'a';

Q1: 為啥當(dāng)子查詢的查詢列表處只有主鍵或者唯一索引列時(shí),就可以直接將子查詢轉(zhuǎn)換為連接查詢呢?

因?yàn)橹麈I或者唯一索引列中的數(shù)據(jù)本身就是不重復(fù)!所以對(duì)于同一條s1表中的記錄,你不可能找到兩條以上的符合s1.key2 =s2.key2的記錄~

2. DuplicateWeedout execution strategy (重復(fù)值消除)

對(duì)于這個(gè)查詢來(lái)說(shuō):

SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a'); 

轉(zhuǎn)換為半連接查詢后,s1表中的某條記錄可能在s2表中有多條匹配的記錄,所以該條記錄可能多次被添加到最后的結(jié)果集中,為了消除重復(fù),我們可以建立一個(gè)臨時(shí)表,比方說(shuō)這個(gè)臨時(shí)表長(zhǎng)這樣:

CREATE TABLE tmp (
  id PRIMARY KEY
 );

這樣在執(zhí)行連接查詢的過(guò)程中,每當(dāng)某條s1表中的記錄要加入結(jié)果集時(shí),就首先把這條記錄的id值加入到這個(gè)臨時(shí)表里,如果添加成功,說(shuō)明之前這條s1表中的記錄并沒(méi)有加入最終的結(jié)果集,現(xiàn)在把該記錄添加到最終的結(jié)果集;如果添加失敗,說(shuō)明這條之前這條s1表中的記錄已經(jīng)加入過(guò)最終的結(jié)果集,這里直接把它丟棄就好了,這種使用臨時(shí)表消除semi-join結(jié)果集中的重復(fù)值的方式稱之為Duplicate Weedout。

3. LooseScan execution strategy (松散索引掃描)

大家看這個(gè)查詢:

SELECT * FROM s1 WHERE key3 IN (SELECT key1 FROM s2 WHERE key1 > 'a' AND key1 < 'b'); 

在子查詢中,對(duì)于s2表的訪問(wèn)可以使用到key1列的索引,而恰好子查詢的查詢列表處就是key1列,這樣在將該查詢轉(zhuǎn)換為半連接查詢后,如果將s2作為驅(qū)動(dòng)表執(zhí)行查詢的話,那么執(zhí)行過(guò)程就是這樣:

如圖所示,在s2表的idx_key1索引中,值為'aa'的二級(jí)索引記錄一共有2條,那么只需要取第一條的值到s1表中查找s1.key3 = 'aa'的記錄,如果能在s1表中找到對(duì)應(yīng)的記錄,那么就把對(duì)應(yīng)的記錄加入到結(jié)果集。依此類推,其他值相同的二級(jí)索引記錄,也只需要取第一條記錄的值到s1表中找匹配的記錄,這種雖然是掃描索引,但只取值相同的記錄的第一條去做匹配操作的方式稱之為松散索引掃描。

4. Semi-join Materialization execution strategy

我們之前介紹的先把外層查詢的IN子句中的不相關(guān)子查詢進(jìn)行物化,然后再進(jìn)行外層查詢的表和物化表的連接本質(zhì)上也算是一種semi-join,只不過(guò)由于物化表中沒(méi)有重復(fù)的記錄,所以可以直接將子查詢轉(zhuǎn)為連接查詢。

5. FirstMatch execution strategy (首次匹配)

FirstMatch是一種最原始的半連接執(zhí)行方式,跟我們年少時(shí)認(rèn)為的相關(guān)子查詢的執(zhí)行方式是一樣一樣的,就是說(shuō)先取一條外層查詢的中的記錄,然后到子查詢的表中尋找符合匹配條件的記錄,如果能找到一條,則將該外層查詢的記錄放入最終的結(jié)果集并且停止查找更多匹配的記錄,如果找不到則把該外層查詢的記錄丟棄掉;然后再開始取下一條外層查詢中的記錄,重復(fù)上邊這個(gè)過(guò)程。

對(duì)于某些使用IN語(yǔ)句的相關(guān)子查詢,比方這個(gè)查詢:

SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE s1.key3 = s2.key3); 

它也可以很方便的轉(zhuǎn)為半連接,轉(zhuǎn)換后的語(yǔ)句類似這樣:

SELECT s1.* FROM s1 SEMI JOIN s2 ON s1.key1 = s2.common_field AND s1.key3 = s2.key3; 

然后就可以使用我們上邊介紹過(guò)的DuplicateWeedout、LooseScan、FirstMatch等半連接執(zhí)行策略來(lái)執(zhí)行查詢,當(dāng)然,如果子查詢的查詢列表處只有主鍵或者唯一二級(jí)索引列,還可以直接使用table pullout的策略來(lái)執(zhí)行查詢,但是需要大家注意的是,由于相關(guān)子查詢并不是一個(gè)獨(dú)立的查詢,所以不能轉(zhuǎn)換為物化表來(lái)執(zhí)行查詢

3.3.4 semi-join的適用條件

當(dāng)然,并不是所有包含IN子查詢的查詢語(yǔ)句都可以轉(zhuǎn)換為semi-join,只有形如這樣的查詢才可以被轉(zhuǎn)換為semi-join

SELECT ... FROM outer_tables WHERE expr IN (SELECT ... FROM inner_tables ...) AND ... 

或者這樣的形式也可以:

SELECT ... FROM outer_tables WHERE (oe1, oe2, ...) IN (SELECT ie1, ie2, ... FROM inner_tables ...) AND ... 

用文字總結(jié)一下,只有符合下邊這些條件的子查詢才可以被轉(zhuǎn)換為semi-join

  • 該子查詢必須是和IN語(yǔ)句組成的布爾表達(dá)式,并且在外層查詢的WHERE或者ON子句中出現(xiàn)
  • 外層查詢也可以有其他的搜索條件,只不過(guò)和IN子查詢的搜索條件必須使用AND連接起來(lái)
  • 該子查詢必須是一個(gè)單一的查詢,不能是由若干查詢由UNION連接起來(lái)的形式
  • 該子查詢不能包含GROUP BY或者HAVING語(yǔ)句或者聚集函數(shù)
  • ... 還有一些條件比較少見,就不嘮叨啦~

3.3.5 不適用于semi-join的情況

對(duì)于一些不能將子查詢轉(zhuǎn)位semi-join的情況,典型的比如下邊這幾種:

1. 外層查詢的WHERE條件中有其他搜索條件與IN子查詢組成的布爾表達(dá)式使用OR連接起來(lái)

SELECT * FROM s1 WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a') OR key2 > 100; 

2. 使用NOT IN而不是IN的情況

SELECT * FROM s1 WHERE key1 NOT IN (SELECT common_field FROM s2 WHERE key3 = 'a') 

3. 在SELECT子句中的IN子查詢的情況

SELECT key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a') FROM s1 ; 

4. 子查詢中包含GROUP BY、HAVING或者聚集函數(shù)的情況

SELECT * FROM s1 WHERE key2 IN (SELECT COUNT(*) FROM s2 GROUP BY key1); 

5. 子查詢中包含UNION的情況

SELECT * FROM s1 WHERE key1 IN (
    SELECT common_field FROM s2 WHERE key3 = 'a'
    UNION
    SELECT common_field FROM s2 WHERE key3 = 'b'
);

MySQL仍然留了兩口絕活來(lái)優(yōu)化不能轉(zhuǎn)為semi-join查詢的子查詢,那就是:

1. 對(duì)于不相關(guān)子查詢來(lái)說(shuō),可以嘗試把它們物化之后再參與查詢

比如我們上邊提到的這個(gè)查詢:

SELECT * FROM s1 WHERE key1 NOT IN (SELECT common_field FROM s2 WHERE key3 = 'a') 

先將子查詢物化,然后再判斷key1是否在物化表的結(jié)果集中可以加快查詢執(zhí)行的速度。

小提示: 請(qǐng)注意這里將子查詢物化之后不能轉(zhuǎn)為和外層查詢的表的連接,只能是先掃描s1表,然后對(duì)s1表的某條記錄來(lái)說(shuō),判斷該記錄的key1值在不在物化表中。

2. 不管子查詢是相關(guān)的還是不相關(guān)的,都可以把IN子查詢嘗試專為EXISTS子查詢

其實(shí)對(duì)于任意一個(gè)IN子查詢來(lái)說(shuō),都可以被轉(zhuǎn)為EXISTS子查詢,通用的例子如下:

outer_expr IN (SELECT inner_expr FROM ... WHERE subquery_where) 

可以被轉(zhuǎn)換為:

EXISTS (SELECT inner_expr FROM ... WHERE subquery_where AND outer_expr=inner_expr) 

當(dāng)然這個(gè)過(guò)程中有一些特殊情況,比如在outer_expr或者inner_expr值為NULL的情況下就比較特殊。因?yàn)橛?code>NULL值作為操作數(shù)的表達(dá)式結(jié)果往往是NULL,比方說(shuō):

mysql> SELECT NULL IN (1, 2, 3);
+-------------------+
| NULL IN (1, 2, 3) |
+-------------------+
|              NULL |
+-------------------+
1 row inset (0.00 sec)
mysql> SELECT 1 IN (1, 2, 3);
+----------------+
| 1 IN (1, 2, 3) |
+----------------+
|              1 |
+----------------+
1 row inset (0.00 sec)
mysql> SELECT NULL IN (NULL);
+----------------+
| NULL IN (NULL) |
+----------------+
|           NULL |
+----------------+
1 row inset (0.00 sec)

而EXISTS子查詢的結(jié)果肯定是TRUE或者FASLE

mysql> SELECT EXISTS (SELECT 1 FROM s1 WHERE NULL = 1);
+------------------------------------------+
| EXISTS (SELECT 1 FROM s1 WHERE NULL = 1) |
+------------------------------------------+
|                                        0 |
+------------------------------------------+
1 row inset (0.01 sec)
mysql> SELECT EXISTS (SELECT 1 FROM s1 WHERE 1 = NULL);
+------------------------------------------+
| EXISTS (SELECT 1 FROM s1 WHERE 1 = NULL) |
+------------------------------------------+
|                                        0 |
+------------------------------------------+
1 row inset (0.00 sec)
mysql> SELECT EXISTS (SELECT 1 FROM s1 WHERE NULL = NULL);
+---------------------------------------------+
| EXISTS (SELECT 1 FROM s1 WHERE NULL = NULL) |
+---------------------------------------------+
|                                           0 |
+---------------------------------------------+
1 row inset (0.00 sec)

但是幸運(yùn)的是,我們大部分使用IN子查詢的場(chǎng)景是把它放在WHERE或者ON子句中,而WHERE或者ON子句是不區(qū)分NULLFALSE的,比方說(shuō):

mysql> SELECT 1 FROM s1 WHERE NULL;
Empty set (0.00 sec)
mysql> SELECT 1 FROM s1 WHERE FALSE;
Empty set (0.00 sec)

所以只要我們的IN子查詢是放在WHERE或者ON子句中的,那么IN -> EXISTS的轉(zhuǎn)換就是沒(méi)問(wèn)題的。說(shuō)了這么多,為啥要轉(zhuǎn)換呢?這是因?yàn)椴晦D(zhuǎn)換的話可能用不到索引,比方說(shuō)下邊這個(gè)查詢:

SELECT * FROM s1 WHERE 
key1 IN (SELECT key3 FROM s2 where s1.common_field = s2.common_field) 
	 OR key2 > 1000;

這個(gè)查詢中的子查詢是一個(gè)相關(guān)子查詢,而且子查詢執(zhí)行的時(shí)候不能使用到索引,但是將它轉(zhuǎn)為EXISTS子查詢后卻可以使用到索引:

SELECT * FROM s1 WHERE EXISTS (SELECT 1 FROM s2 wheres1.common_field = s2.common_field AND s2.key3 = s1.key1) OR key2 > 1000; 

轉(zhuǎn)為EXISTS子查詢時(shí)便可以使用到s2表的idx_key3索引了。

需要注意的是,如果IN子查詢不滿足轉(zhuǎn)換為semi-join的條件,又不能轉(zhuǎn)換為物化表或者轉(zhuǎn)換為物化表的成本太大,那么它就會(huì)被轉(zhuǎn)換為EXISTS查詢。

小提示: 在MySQL5.5以及之前的版本沒(méi)有引進(jìn)semi-join和物化的方式優(yōu)化子查詢時(shí),優(yōu)化器都會(huì)把IN子查詢轉(zhuǎn)換為EXISTS子查詢,好多同學(xué)就驚呼我明明寫的是一個(gè)不相關(guān)子查詢,為啥要按照?qǐng)?zhí)行相關(guān)子查詢的方式來(lái)執(zhí)行呢?所以當(dāng)時(shí)好多聲音都是建議大家把子查詢轉(zhuǎn)為連接,不過(guò)隨著MySQL的發(fā)展,最近的版本中引入了非常多的子查詢優(yōu)化策略,大家可以稍微放心的使用子查詢了,內(nèi)部的轉(zhuǎn)換工作優(yōu)化器會(huì)為大家自動(dòng)實(shí)現(xiàn)。

小結(jié)一下

如果IN子查詢符合轉(zhuǎn)換為semi-join的條件,查詢優(yōu)化器會(huì)優(yōu)先把該子查詢轉(zhuǎn)換為semi-join,然后再考慮下邊5種執(zhí)行半連接的策略中哪個(gè)成本最低:

  • Table pullout
  • DuplicateWeedout
  • LooseScan Materialization
  • FirstMatch 選擇成本最低的那種執(zhí)行策略來(lái)執(zhí)行子查詢。

如果IN子查詢不符合轉(zhuǎn)換為semi-join的條件,那么查詢優(yōu)化器會(huì)從下邊兩種策略中找出一種成本更低的方式執(zhí)行子查詢:

  • 先將子查詢物化之后再執(zhí)行查詢
  • 執(zhí)行IN to EXISTS轉(zhuǎn)換。

3.4 ANY/ALL子查詢優(yōu)化

如果ANY/ALL子查詢是不相關(guān)子查詢的話,它們?cè)诤芏鄨?chǎng)合都能轉(zhuǎn)換成我們熟悉的方式去執(zhí)行,比方說(shuō):

原始表達(dá)式轉(zhuǎn)換為
< ANY (SELECT inner_expr ...)< (SELECT MAX(inner_expr) ...)
> ANY (SELECT inner_expr ...)> (SELECT MIN(inner_expr) ...)
< ALL (SELECT inner_expr ...)< (SELECT MIN(inner_expr) ...)
> ALL (SELECT inner_expr ...)> (SELECT MAX(inner_expr) ...)

3.5 [NOT] EXISTS子查詢的執(zhí)行

如果[NOT] EXISTS子查詢是不相關(guān)子查詢,可以先執(zhí)行子查詢,得出該[NOT] EXISTS子查詢的結(jié)果是TRUE還是FALSE,并重寫原先的查詢語(yǔ)句,比如對(duì)這個(gè)查詢來(lái)說(shuō):

SELECT * FROM s1 WHERE EXISTS (SELECT 1 FROM s2 WHERE key1 = 'a') OR key2 > 100; 

因?yàn)檫@個(gè)語(yǔ)句里的子查詢是不相關(guān)子查詢,所以優(yōu)化器會(huì)首先執(zhí)行該子查詢,假設(shè)該EXISTS子查詢的結(jié)果為TRUE,那么接著優(yōu)化器會(huì)重寫查詢?yōu)椋?/p>

SELECT * FROM s1 WHERE TRUE OR key2 > 100; 

進(jìn)一步簡(jiǎn)化后就變成了:

SELECT * FROM s1 WHERE TRUE; 

對(duì)于相關(guān)的[NOT] EXISTS子查詢來(lái)說(shuō),比如這個(gè)查詢:

SELECT * FROM s1 WHERE EXISTS (SELECT 1 FROM s2 WHERE s1.common_field = s2.common_field); 

很不幸,這個(gè)查詢只能按照我們年少時(shí)的那種執(zhí)行相關(guān)子查詢的方式來(lái)執(zhí)行。不過(guò)如果[NOT] EXISTS子查詢中如果可以使用索引的話,那查詢速度也會(huì)加快不少,比如:

SELECT * FROM s1 WHERE EXISTS (SELECT 1 FROM s2 WHERE s1.common_field = s2.key1); 

上邊這個(gè)EXISTS子查詢中可以使用idx_key1來(lái)加快查詢速度。

3.6 對(duì)于派生表的優(yōu)化

我們前邊說(shuō)過(guò)把子查詢放在外層查詢的FROM子句后,那么這個(gè)子查詢的結(jié)果相當(dāng)于一個(gè)派生表,比如下邊這個(gè)查詢:

SELECT * FROM  (
        SELECT id AS d_id,  key3 AS d_key3 FROM s2 WHERE key1 = 'a'
    ) AS derived_s1 WHERE d_key3 = 'a';

子查詢( SELECT id AS d_id, key3 AS d_key3 FROM s2 WHERE key1 = 'a')的結(jié)果就相當(dāng)于一個(gè)派生表,這個(gè)表的名稱是derived_s1,該表有兩個(gè)列,分別是d_idd_key3

對(duì)于含有派生表的查詢,MySQL提供了兩種執(zhí)行策略:

1. 最容易想到的就是把派生表物化

我們可以將派生表的結(jié)果集寫到一個(gè)內(nèi)部的臨時(shí)表中,然后就把這個(gè)物化表當(dāng)作普通表一樣參與查詢。當(dāng)然,在對(duì)派生表進(jìn)行物化時(shí),MySQL使用了一種稱為延遲物化的策略,也就是在查詢中真正使用到派生表時(shí)才回去嘗試物化派生表,而不是還沒(méi)開始執(zhí)行查詢呢就把派生表物化掉。比方說(shuō)對(duì)于下邊這個(gè)含有派生表的查詢來(lái)說(shuō):

SELECT * FROM (
        SELECT * FROM s1 WHERE key1 = 'a'
    ) AS derived_s1 INNER JOIN s2
    ON derived_s1.key1 = s2.key1
    WHERE s2.key2 = 1;

如果采用物化派生表的方式來(lái)執(zhí)行這個(gè)查詢的話,那么執(zhí)行時(shí)首先會(huì)到s2表中找出滿足s2.key2 = 1的記錄,如果壓根?找不到,說(shuō)明參與連接的s2表記錄就是空的,所以整個(gè)查詢的結(jié)果集就是空的,所以也就沒(méi)有必要去物化查詢中的派生表了。

2. 將派生表和外層的表合并,也就是將查詢重寫為沒(méi)有派生表的形式

我們來(lái)看這個(gè)賊簡(jiǎn)單的包含派生表的查詢:

SELECT * FROM (SELECT * FROM s1 WHERE key1 = 'a') AS derived_s1; 

這個(gè)查詢本質(zhì)上就是想查看s1表中滿足key1 = 'a'條件的的全部記錄,所以和下邊這個(gè)語(yǔ)句是等價(jià)的:

SELECT * FROM s1 WHERE key1 = 'a'; 

對(duì)于一些稍微復(fù)雜的包含派生表的語(yǔ)句,比如我們上邊提到的那個(gè):

SELECT * FROM (
        SELECT * FROM s1 WHERE key1 = 'a'
    ) AS derived_s1 INNER JOIN s2
    ON derived_s1.key1 = s2.key1
    WHERE s2.key2 = 1;

我們可以將派生表與外層查詢的表合并,然后將派生表中的搜索條件放到外層查詢的搜索條件中,就像這樣:

SELECT * FROM s1 INNER JOIN s2 ON s1.key1 = s2.key1 WHERE s1.key1 = 'a' AND s2.key2 = 1; 

這樣通過(guò)將外層查詢和派生表合并的方式成功的消除了派生表,也就意味著我們沒(méi)必要再付出創(chuàng)建和訪問(wèn)臨時(shí)表的成本了。可是并不是所有帶有派生表的查詢都能被成功的和外層查詢合并,當(dāng)派生表中有這些語(yǔ)句就不可以和外層查詢合并:

  • 聚集函數(shù),比如MAX()、MIN()、SUM()啥的
  • DISTINCT
  • GROUP BY
  • HAVING
  • LIMIT
  • UNION 或者 UNION ALL
  • 派生表對(duì)應(yīng)的子查詢的SELECT子句中含有另一個(gè)子查詢
  • ... 還有些不常用的情況就不多說(shuō)了哈~

所以MySQL在執(zhí)行帶有派生表的時(shí)候,優(yōu)先嘗試把派生表和外層查詢合并掉,如果不行的話,再把派生表物化掉執(zhí)行查詢。

至此今天的學(xué)習(xí)就到此結(jié)束了,愿您成為堅(jiān)不可摧的自己~~~

以上就是一文帶你了解MySQL基于規(guī)則的優(yōu)化的詳細(xì)內(nèi)容,更多關(guān)于MySQL基于規(guī)則優(yōu)化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • centos7利用yum安裝mysql 8.0.12

    centos7利用yum安裝mysql 8.0.12

    這篇文章主要為大家詳細(xì)介紹了centos7利用yum安裝mysql 8.0.12,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • mysql日志系統(tǒng)redo log和bin log介紹

    mysql日志系統(tǒng)redo log和bin log介紹

    這篇文章主要介紹了mysql日志系統(tǒng)redo log和bin log介紹,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • Mysql數(shù)據(jù)庫(kù)中把varchar類型轉(zhuǎn)化為int類型的方法

    Mysql數(shù)據(jù)庫(kù)中把varchar類型轉(zhuǎn)化為int類型的方法

    這篇文章主要介紹了Mysql數(shù)據(jù)庫(kù)中把varchar類型轉(zhuǎn)化為int類型的方法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-07-07
  • MySQL如何實(shí)現(xiàn)兩張表取差集

    MySQL如何實(shí)現(xiàn)兩張表取差集

    這篇文章主要介紹了MySQL如何實(shí)現(xiàn)兩張表取差集問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • MySQL asc、desc數(shù)據(jù)排序的實(shí)現(xiàn)

    MySQL asc、desc數(shù)據(jù)排序的實(shí)現(xiàn)

    這篇文章主要介紹了MySQL asc、desc數(shù)據(jù)排序的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • mysql數(shù)據(jù)庫(kù)decimal類型與decimal長(zhǎng)度用法詳解

    mysql數(shù)據(jù)庫(kù)decimal類型與decimal長(zhǎng)度用法詳解

    在MySQL中decimal是一種用于存儲(chǔ)精確數(shù)字的數(shù)據(jù)類型,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫(kù)decimal類型與decimal長(zhǎng)度用法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-01-01
  • MySQL時(shí)間戳與日期格式的相互轉(zhuǎn)換

    MySQL時(shí)間戳與日期格式的相互轉(zhuǎn)換

    在MySQL數(shù)據(jù)庫(kù)中,時(shí)間戳和日期格式是常用的數(shù)據(jù)類型,在MySQL中,我們可以使用函數(shù)還相互轉(zhuǎn)換時(shí)間戳和日期格式,下面我將詳細(xì)的給大家介紹如何進(jìn)行轉(zhuǎn)換,并提供相應(yīng)的代碼示例,感興趣的小伙伴跟著小編一起來(lái)看看吧
    2024-01-01
  • Mysql一對(duì)多輕松實(shí)現(xiàn)追蹤歷史首條記錄

    Mysql一對(duì)多輕松實(shí)現(xiàn)追蹤歷史首條記錄

    本文介紹了在數(shù)據(jù)庫(kù)中處理一對(duì)多關(guān)系時(shí),如何使用JOIN和WHERE子句來(lái)找到每個(gè)主表記錄對(duì)應(yīng)的子表中特定記錄(例如時(shí)間最早的記錄),通過(guò)將B表與自身進(jìn)行比較并使用MIN()函數(shù),可以精確匹配到所需記錄
    2024-12-12
  • mysql全面解析json/數(shù)組

    mysql全面解析json/數(shù)組

    這篇文章主要介紹了mysql全面解析json/數(shù)組,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 在linux服務(wù)器上配置mysql并開放3306端口的操作步驟

    在linux服務(wù)器上配置mysql并開放3306端口的操作步驟

    這篇文章主要介紹了在linux服務(wù)器上配置mysql并開放3306端口,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09

最新評(píng)論

亚洲偷自拍高清视频| 亚洲午夜高清在线观看| 亚洲成人三级在线播放 | 国产精品3p和黑人大战| 亚洲欧美国产综合777| 天堂中文字幕翔田av| 快插进小逼里大鸡吧视频| 亚洲中文字幕人妻一区| 亚洲国产精品免费在线观看| 老司机福利精品免费视频一区二区 | 日本人妻少妇18—xx| 欧美日韩高清午夜蜜桃大香蕉| 国产高清97在线观看视频| 成人18禁网站在线播放| 女生自摸在线观看一区二区三区| 粉嫩小穴流水视频在线观看| 国产熟妇乱妇熟色T区| 亚洲 中文字幕在线 日韩| 北条麻妃肉色丝袜视频| 久久精品亚洲国产av香蕉| 中文字幕人妻av在线观看| 一区二区三区精品日本| 国产乱子伦精品视频潮优女| 亚洲欧美另类手机在线| 亚洲综合一区二区精品久久| 经典av尤物一区二区| 亚洲国产欧美一区二区三区…| 婷婷激情四射在线观看视频| aⅴ精产国品一二三产品| 把腿张开让我插进去视频| 色综合久久五月色婷婷综合| 岛国青草视频在线观看| 少妇人妻真实精品视频| 超碰97免费人妻麻豆| 18禁无翼鸟成人在线| 欧洲精品第一页欧洲精品亚洲| 含骚鸡巴玩逼逼视频| 超级碰碰在线视频免费观看| 98视频精品在线观看| 久久久久久cao我的性感人妻| 午夜激情久久不卡一区二区| 久久精品在线观看一区二区| 国产午夜男女爽爽爽爽爽视频| 国产97在线视频观看| 天天日天天爽天天干| 精品久久久久久高潮| 99亚洲美女一区二区三区| 日韩无码国产精品强奸乱伦| 国产中文字幕四区在线观看| jiujiure精品视频在线| 青青草人人妻人人妻| 精品国产午夜视频一区二区| 999九九久久久精品| 人妻自拍视频中国大陆| 三上悠亚和黑人665番号| 国产福利在线视频一区| 中文字母永久播放1区2区3区 | 日本少妇人妻xxxxx18| 天堂av在线最新版在线| 成年午夜免费无码区| 天天干天天日天天干天天操| 人人在线视频一区二区| 中文字幕一区二 区二三区四区| 久久久久久性虐视频| 中文字幕在线观看国产片| 国产一线二线三线的区别在哪| 自拍 日韩 欧美激情| 91九色国产porny蝌蚪| 亚洲精品欧美日韩在线播放| 老司机免费视频网站在线看| 一区二区三区久久久91| 亚洲av人人澡人人爽人人爱| 国产九色91在线观看精品| 男人操女人的逼免费视频| 久久久制服丝袜中文字幕| 欧美日韩情色在线观看| 精品人妻伦一二三区久| 欧美香蕉人妻精品一区二区| 亚洲成av人无码不卡影片一| 免费成人av中文字幕| 含骚鸡巴玩逼逼视频| 日本免费一级黄色录像| 不卡一不卡二不卡三| 亚洲av成人网在线观看| 亚洲专区激情在线观看视频| 亚洲精品成人网久久久久久小说| 三级av中文字幕在线观看| 亚洲最大免费在线观看| 97精品综合久久在线| 91福利在线视频免费观看| 国产亚洲成人免费在线观看| 白白操白白色在线免费视频 | 亚洲av男人天堂久久| 日本少妇高清视频xxxxx| 三上悠亚和黑人665番号| 欧美一区二区三区乱码在线播放| 91片黄在线观看喷潮| 亚洲欧美激情国产综合久久久| 偷偷玩弄新婚人妻h视频| 青青青青视频在线播放| 国产精品国产三级国产精东| 亚洲一区二区三区av网站| 成人福利视频免费在线| 天天日天天爽天天干| 粉嫩av蜜乳av蜜臀| 水蜜桃国产一区二区三区| 蜜桃视频在线欧美一区| 天天干天天插天天谢| 真实国模和老外性视频| 亚洲美女美妇久久字幕组| 免费黄色成人午夜在线网站| 欧美一区二区三区在线资源| 丝袜肉丝一区二区三区四区在线看| 日本成人一区二区不卡免费在线| 日韩美av高清在线| 天码人妻一区二区三区在线看| 日韩近亲视频在线观看| 蜜桃专区一区二区在线观看| 1区2区3区不卡视频| 快点插进来操我逼啊视频| 欧美综合婷婷欧美综合| 大白屁股精品视频国产| 人妻少妇精品久久久久久| 日韩美女综合中文字幕pp| 欧美久久久久久三级网| 欧美黑人性猛交xxxxⅹooo| 班长撕开乳罩揉我胸好爽| 黄页网视频在线免费观看| 人妻另类专区欧美制服| 97精品成人一区二区三区 | 日日夜夜大香蕉伊人| 欧美黄片精彩在线免费观看| 日韩欧美一级精品在线观看| 国产日本欧美亚洲精品视| 天美传媒mv视频在线观看| 色花堂在线av中文字幕九九| 视频一区 二区 三区 综合| 深夜男人福利在线观看| 亚国产成人精品久久久| 亚洲精品无码色午夜福利理论片| 日韩欧美国产精品91| 国产精选一区在线播放| 无码日韩人妻精品久久| 国产 在线 免费 精品| 性生活第二下硬不起来| 综合一区二区三区蜜臀| 欧美区一区二区三视频| 又大又湿又爽又紧A视频| 超碰97人人澡人人| 亚洲公开视频在线观看| 国产美女一区在线观看| 2022国产综合在线干| 97超碰免费在线视频| 午夜在线一区二区免费| 亚洲图库另类图片区| 18禁污污污app下载| 天天射,天天操,天天说| 91国产在线视频免费观看| 揄拍成人国产精品免费看视频| 中国熟女@视频91| 亚洲人一区二区中文字幕| 久久三久久三久久三久久| 岛国毛片视频免费在线观看| 久久久超爽一二三av| 天天色天天操天天舔| 成熟丰满熟妇高潮xx×xx| 成人高潮aa毛片免费| 天天艹天天干天天操| 欧美地区一二三专区| 男人在床上插女人视频| av黄色成人在线观看| 97人妻夜夜爽二区欧美极品| 精品亚洲国产中文自在线| 久久久久久久久久一区二区三区| 国产精品伦理片一区二区| 91av中文视频在线| 亚洲av极品精品在线观看| 骚货自慰被发现爆操| 大陆精品一区二区三区久久| 青青草原网站在线观看| 中文字幕高清在线免费播放| 亚洲中文精品字幕在线观看| 亚洲人妻30pwc| 91国产在线免费播放| 偷拍美女一区二区三区| 大胸性感美女羞爽操逼毛片| 97瑟瑟超碰在线香蕉| 中文字幕综合一区二区| 国产男女视频在线播放| 青青热久免费精品视频在线观看| 熟女人妻在线观看视频| 在线成人日韩av电影| 97人人模人人爽人人喊| 天堂女人av一区二区| 国产一区二区欧美三区| 久久香蕉国产免费天天| 大香蕉大香蕉在线看| 国产chinesehd精品麻豆| 在线观看欧美黄片一区二区三区| 国产露脸对白在线观看| 中文字幕在线观看国产片| 伊人综合免费在线视频| 无码国产精品一区二区高潮久久4| 91人妻精品久久久久久久网站| 天天操天天射天天操天天天| 蜜桃精品久久久一区二区| 99热碰碰热精品a中文| 在线制服丝袜中文字幕| 欧美偷拍自拍色图片| av中文字幕在线观看第三页| 欧美精产国品一二三区| 国产精品成久久久久三级蜜臀av| 久久久噜噜噜久久熟女av| 操人妻嗷嗷叫视频一区二区| 国产精品亚洲在线观看| 一区二区久久成人网| 福利片区一区二体验区| 999九九久久久精品| 亚洲欧美人精品高清| 亚洲熟妇x久久av久久| 51国产成人精品视频| 成年人该看的视频黄免费| 亚洲免费va在线播放| 91免费黄片可看视频| 亚洲午夜电影在线观看| 男女啪啪啪啪啪的网站| 视频 一区二区在线观看| 国产品国产三级国产普通话三级| 无码精品一区二区三区人| 91av精品视频在线| 欧美男人大鸡吧插女人视频| 亚洲一区av中文字幕在线观看| 免费大片在线观看视频网站| 成人18禁网站在线播放| 天天操,天天干,天天射| 综合页自拍视频在线播放| 性欧美激情久久久久久久| 亚洲 色图 偷拍 欧美| 五月婷婷在线观看视频免费| 99久久中文字幕一本人| 深夜男人福利在线观看| 美女福利写真在线观看视频| 大肉大捧一进一出好爽在线视频| 日本又色又爽又黄又粗| 美女大bxxxx内射| 专门看国产熟妇的网站| 欧美一级色视频美日韩| 91九色国产熟女一区二区| 午夜婷婷在线观看视频| 免费在线黄色观看网站| 一区二区在线观看少妇| 久久久久久久久久久久久97| 欧美成一区二区三区四区| 精品人人人妻人人玩日产欧| 初美沙希中文字幕在线| av中文字幕在线导航| 午夜的视频在线观看| 国产欧美日韩在线观看不卡| 99热这里只有精品中文| 亚洲激情偷拍一区二区| 护士小嫩嫩又紧又爽20p| 中国产一级黄片免费视频播放| 在线观看黄色成年人网站| 青青热久免费精品视频在线观看| 天天干天天日天天谢综合156| 亚洲1069综合男同| 色婷婷六月亚洲综合香蕉| 老司机99精品视频在线观看 | 粉嫩小穴流水视频在线观看| 91综合久久亚洲综合| 色哟哟国产精品入口| 在线国产中文字幕视频| 欧美熟妇一区二区三区仙踪林| 天天干天天插天天谢| 中字幕人妻熟女人妻a62v网| 成人午夜电影在线观看 久久| 9色精品视频在线观看| 宅男噜噜噜666国产| 久草视频在线一区二区三区资源站 | 免费男阳茎伸入女阳道视频| 欧美激情精品在线观看| 国产精品人妻一区二区三区网站| 在线观看视频一区麻豆| 亚洲欧美激情中文字幕| 日本女人一级免费片| 无忧传媒在线观看视频| 亚洲一区二区久久久人妻| 欧美视频不卡一区四区| 日日爽天天干夜夜操| av手机在线免费观看日韩av| 国产av国片精品一区二区| 免费观看成年人视频在线观看| 色狠狠av线不卡香蕉一区二区| 日本一本午夜在线播放| 午夜91一区二区三区| 久久久久久久亚洲午夜综合福利| 狠狠躁狠狠爱网站视频| 免费一级特黄特色大片在线观看 | 成人av在线资源网站| av线天堂在线观看| 97国产福利小视频合集| 久久精品美女免费视频| 日本特级片中文字幕| 国产精品黄片免费在线观看| 91亚洲精品干熟女蜜桃频道| 99久久久无码国产精品性出奶水 | 精品视频中文字幕在线播放 | 亚洲欧美在线视频第一页| 天天躁夜夜躁日日躁a麻豆| 毛片av在线免费看| 国产成人精品福利短视频| 在线视频国产欧美日韩| 欧美伊人久久大香线蕉综合| 午夜精品一区二区三区4| 日本成人一区二区不卡免费在线| 久久机热/这里只有| 红桃av成人在线观看| 欧美亚洲偷拍自拍色图| 最近中文字幕国产在线| 超碰公开大香蕉97| 97人人妻人人澡人人爽人人精品| 国产性感美女福利视频| 2022精品久久久久久中文字幕| 亚洲国际青青操综合网站| 中文字幕之无码色多多| 欧洲精品第一页欧洲精品亚洲| 日本性感美女写真视频| 操操网操操伊剧情片中文字幕网| 亚洲一区二区三区在线高清| 一色桃子人妻一区二区三区| 久久久精品欧洲亚洲av| 日韩少妇人妻精品无码专区| 视频在线亚洲一区二区| 免费在线福利小视频| 亚洲熟色妇av日韩熟色妇在线| 欧美日本在线观看一区二区| 天堂av中文在线最新版| 国产露脸对白在线观看| 天天草天天色天天干| 老司机午夜精品视频资源 | 欧美日韩高清午夜蜜桃大香蕉| 中文字幕日韩精品就在这里| 一区二区三区日本伦理| 亚洲男人让女人爽的视频| 亚洲欧美激情人妻偷拍| 亚洲欧美激情人妻偷拍| 国产精品3p和黑人大战| 欧美黄片精彩在线免费观看| 国产妇女自拍区在线观看| 亚洲中文精品字幕在线观看 | 蝴蝶伊人久久中文娱乐网| 2021年国产精品自拍| 一区二区三区日本伦理| 人人人妻人人澡人人| 精品亚洲中文字幕av| 亚洲熟女久久久36d| 99精品久久久久久久91蜜桃| 日韩欧美一级aa大片| 亚洲高清免费在线观看视频| 国产aⅴ一线在线观看| 91极品新人『兔兔』精品新作| 特级欧美插插插插插bbbbb| 老熟妇凹凸淫老妇女av在线观看| 欧美专区第八页一区在线播放 | 国产在线自在拍91国语自产精品| 91av中文视频在线| www,久久久,com| av俺也去在线播放| 黄色成人在线中文字幕| 日韩精品激情在线观看| 98视频精品在线观看| 黄色片一级美女黄色片| 久草视频中文字幕在线观看| 国产精品福利小视频a| 清纯美女在线观看国产| 亚洲粉嫩av一区二区三区| 欧美一区二区中文字幕电影| av在线免费中文字幕| 成人av免费不卡在线观看| 中文字幕高清在线免费播放| 日本五十路熟新垣里子| 亚洲 国产 成人 在线| 日韩亚国产欧美三级涩爱| 亚洲av日韩精品久久久久久hd| 丝袜国产专区在线观看| 风流唐伯虎电视剧在线观看| 精品一线二线三线日本| 成人高清在线观看视频| 视频在线免费观看你懂得| 中文字幕人妻被公上司喝醉在线| 偷拍自拍 中文字幕| 92福利视频午夜1000看 | 超pen在线观看视频公开97 | 66久久久久久久久久久| 日韩欧美国产一区不卡| 啊啊好慢点插舔我逼啊啊啊视频| 黄色的网站在线免费看| 亚洲国产欧美一区二区丝袜黑人| 97小视频人妻一区二区| 成熟熟女国产精品一区| 九九视频在线精品播放| 亚洲国产精品久久久久久6| 欧美一区二区三区激情啪啪啪| 999热精品视频在线| 国产精品久久9999| 日韩精品电影亚洲一区| 丁香花免费在线观看中文字幕| 久久久久久久精品成人热| 久草极品美女视频在线观看| 人妻最新视频在线免费观看| 3344免费偷拍视频| 午夜精品九一唐人麻豆嫩草成人| 日韩精品激情在线观看| 好吊视频—区二区三区| 人人爱人人妻人人澡39| 日本熟女精品一区二区三区| 伊人网中文字幕在线视频| 欧美日韩激情啪啪啪| 把腿张开让我插进去视频| 午夜精彩视频免费一区| 99精品视频在线观看免费播放| 社区自拍揄拍尻屁你懂的| 天天操天天干天天日狠狠插| 在线网站你懂得老司机| 国产一区二区火爆视频| 99久久激情婷婷综合五月天| 被大鸡吧操的好舒服视频免费| 2021久久免费视频| 性感美女高潮视频久久久| 亚洲女人的天堂av| 天码人妻一区二区三区在线看| 热99re69精品8在线播放| 欧美精品一二三视频| 亚洲人成精品久久久久久久| 视频一区 视频二区 视频| 亚洲国产免费av一区二区三区| 在线观看av观看av| 亚洲精品久久综合久| 国产一级麻豆精品免费| 亚洲国产精品免费在线观看| 91国产在线免费播放| 亚洲免费成人a v| 天天插天天狠天天操| 漂亮 人妻被中出中文| 免费成人va在线观看| 91片黄在线观看喷潮| 免费高清自慰一区二区三区网站| 一区二区三区久久久91| 亚洲一区二区三区久久受| 日本熟妇丰满厨房55| 免费人成黄页网站在线观看国产| 超级av免费观看一区二区三区| 国产精品sm调教视频| 日韩人妻丝袜中文字幕| 国产精品亚洲在线观看| 99久久99一区二区三区| 中出中文字幕在线观看| 中文字幕AV在线免费看 | 亚洲av日韩精品久久久久久hd| 夜色撩人久久7777| 97资源人妻免费在线视频| 在线观看av观看av| 在线免费观看亚洲精品电影| 亚洲老熟妇日本老妇| 成人蜜桃美臀九一一区二区三区| 天天干夜夜操天天舔| 三级黄色亚洲成人av| 国产精品黄大片在线播放| 在线观看av2025| 香港三日本三韩国三欧美三级| 国产中文字幕四区在线观看| 2012中文字幕在线高清| 亚洲精品在线资源站| 日本一二三中文字幕| 天美传媒mv视频在线观看| 亚洲av日韩高清hd| 97超碰免费在线视频| 一级黄片大鸡巴插入美女| 亚洲偷自拍高清视频| 人妻自拍视频中国大陆| 中国黄片视频一区91| 一区二区三区欧美日韩高清播放| 日本精品美女在线观看| 日本黄在免费看视频| 亚洲自拍偷拍综合色| 99久久中文字幕一本人| 国产视频在线视频播放| 国产欧美精品不卡在线| 亚洲成人激情视频免费观看了 | 亚洲国产精品免费在线观看| 硬鸡巴动态操女人逼视频| 成年人啪啪视频在线观看| 国产乱弄免费视频观看| 国产精品视频男人的天堂| 国产精品视频资源在线播放| 精品av国产一区二区三区四区| 亚洲码av无色中文| 97国产精品97久久| 2022天天干天天操| 无码国产精品一区二区高潮久久4| 日本午夜爽爽爽爽爽视频在线观看| 中文字幕在线第一页成人| 97年大学生大白天操逼| 国产精品日韩欧美一区二区| 国产又粗又猛又爽又黄的视频美国| 亚洲一级美女啪啪啪| 亚洲欧美自拍另类图片| 初美沙希中文字幕在线| 2021最新热播中文字幕| 大白屁股精品视频国产| 少妇ww搡性bbb91| 三级av中文字幕在线观看| 亚洲久久午夜av一区二区| 亚洲av日韩av网站| 国产97视频在线精品| 人妻素人精油按摩中出| 久久三久久三久久三久久| 91破解版永久免费| 欧美亚洲中文字幕一区二区三区 | 日本女人一级免费片| 扒开让我视频在线观看| 国产视频在线视频播放| 免费人成黄页网站在线观看国产 | 久久久精品999精品日本 | 一本久久精品一区二区| 精品国产在线手机在线| nagger可以指黑人吗| 午夜福利资源综合激情午夜福利资| 久草视频在线免播放| 噜噜色噜噜噜久色超碰| 国产精品成久久久久三级蜜臀av | 91国产在线视频免费观看| 激情人妻校园春色亚洲欧美| nagger可以指黑人吗| 又黄又刺激的午夜小视频| jiuse91九色视频| 亚洲国产欧美国产综合在线 | 一区二区久久成人网| 中文字幕亚洲久久久| 久久久久久性虐视频| 2012中文字幕在线高清| 亚洲国产欧美一区二区三区…| 欧美精品中文字幕久久二区| 亚洲天堂精品福利成人av| 玖玖一区二区在线观看| 国产伦精品一区二区三区竹菊| 中文字幕免费福利视频6| 91精品一区二区三区站长推荐| 日韩影片一区二区三区不卡免费| 青青青青青青青在线播放视频| 极品性荡少妇一区二区色欲| 内射久久久久综合网| 丰满的继坶3中文在线观看| 老司机99精品视频在线观看| 青娱乐在线免费视频盛宴| 韩国黄色一级二级三级| 欧美一区二区三区在线资源 | 青青青青青操视频在线观看| 日本男女操逼视频免费看| 欧美成一区二区三区四区| 午夜精品一区二区三区更新| 欧美日韩情色在线观看| 免费观看污视频网站| 在线免费观看黄页视频| 五十路熟女人妻一区二区9933| 中文字幕无码一区二区免费| 欧美日韩熟女一区二区三区| 亚洲中文字幕综合小综合| 小泽玛利亚视频在线观看| 夜夜骑夜夜操夜夜奸| 天天日天天干天天插舔舔| 欧美精品中文字幕久久二区| 喷水视频在线观看这里只有精品| 最新国产亚洲精品中文在线| 日比视频老公慢点好舒服啊| 久草视频 久草视频2| 国产老熟女伦老熟妇ⅹ| av中文字幕网址在线| 91天堂天天日天天操| ka0ri在线视频| 日本黄在免费看视频| 国产又大又黄免费观看| 日本一区精品视频在线观看| 欧美精品免费aaaaaa| 精品视频一区二区三区四区五区| 中文字幕无码日韩专区免费| 婷婷色国产黑丝少妇勾搭AV| 亚洲国产成人在线一区| 女生被男生插的视频网站| 日韩人妻在线视频免费| 亚洲1069综合男同| 日韩在线视频观看有码在线| 青娱乐极品视频青青草| 超碰公开大香蕉97| 欧美性受xx黑人性猛交| 99视频精品全部15| 日韩欧美国产一区ab| 在线国产中文字幕视频| 国产午夜无码福利在线看| 最新中文字幕乱码在线| 欧美aa一级一区三区四区| 亚洲国产免费av一区二区三区| 毛片av在线免费看| 成人蜜臀午夜久久一区| 色在线观看视频免费的| 少妇ww搡性bbb91| 亚洲久久午夜av一区二区| 99久久99一区二区三区| 97香蕉碰碰人妻国产樱花| 亚洲国际青青操综合网站| 亚洲日本一区二区久久久精品| 国产品国产三级国产普通话三级| 国产日韩av一区二区在线| 国产九色91在线视频| 精彩视频99免费在线| 精品亚洲在线免费观看| 日韩欧美高清免费在线| 国产视频一区在线观看| 中文字日产幕乱六区蜜桃| 亚洲日本一区二区三区| 黑人3p华裔熟女普通话| 狍和女人的王色毛片| 一级黄色av在线观看| 亚洲国产精品美女在线观看| 欧美国产亚洲中英文字幕| 中文字幕日本人妻中出| 玖玖一区二区在线观看| 男人的网址你懂的亚洲欧洲av| 日韩特级黄片高清在线看| 欲乱人妻少妇在线视频裸| 欧美久久久久久三级网| 成年午夜影片国产片| 成人国产小视频在线观看| 熟女国产一区亚洲中文字幕| 天堂女人av一区二区| 青青青青爽手机在线| 日韩精品啪啪视频一道免费| 国产中文字幕四区在线观看| 在线视频这里只有精品自拍| 亚洲精品成人网久久久久久小说| 曰本无码人妻丰满熟妇啪啪| 午夜精品久久久久久99热| 国产精品久久综合久久| 久久丁香花五月天色婷婷| 国产日韩欧美美利坚蜜臀懂色| 中文字幕日韩无敌亚洲精品| 天天插天天色天天日| 都市激情校园春色狠狠| 91极品大一女神正在播放| tube69日本少妇| 沙月文乃人妻侵犯中文字幕在线 | 亚洲麻豆一区二区三区| 久草视频首页在线观看| 福利一二三在线视频观看| 亚洲 欧美 自拍 偷拍 在线| 男人的天堂av日韩亚洲| 93人妻人人揉人人澡人人| 国产日韩欧美美利坚蜜臀懂色| 国产视频网站国产视频| 国产高清精品极品美女| 传媒在线播放国产精品一区| 久久精品视频一区二区三区四区| 日本少妇高清视频xxxxx| 自拍偷拍亚洲精品第2页| 男女之间激情网午夜在线| 摧残蹂躏av一二三区| 精品人人人妻人人玩日产欧| 日本后入视频在线观看 | 天堂av在线最新版在线| 亚洲欧美一卡二卡三卡| 一区二区三区麻豆福利视频| nagger可以指黑人吗| 精品高跟鞋丝袜一区二区| av资源中文字幕在线观看| 国产亚洲欧美另类在线观看| 一级黄色片夫妻性生活| 欧美专区第八页一区在线播放| 视频 一区二区在线观看| 色综合久久五月色婷婷综合| 18禁网站一区二区三区四区| 国产午夜亚洲精品麻豆| 亚洲av日韩精品久久久| 夜色福利视频在线观看| 岛国一区二区三区视频在线| 国产精品女邻居小骚货| 中字幕人妻熟女人妻a62v网| 久精品人妻一区二区三区| 欧美性感尤物人妻在线免费看| 蜜臀av久久久久久久| 国产无遮挡裸体免费直播视频| 日本精品视频不卡一二三| 97人妻色免费视频| 欧美在线精品一区二区三区视频 | 日韩美女搞黄视频免费| 国产精品国产三级麻豆| 亚洲国产在人线放午夜| 国产精品久久9999| 性欧美日本大妈母与子| 天天日天天干天天插舔舔| 人人妻人人人操人人人爽| 国产精品成人xxxx| avjpm亚洲伊人久久| 色婷婷综合激情五月免费观看| 久久久久久99国产精品| 国产精品福利小视频a| 精品国产在线手机在线| 亚洲综合一区成人在线| 精品亚洲在线免费观看| 亚洲熟女综合色一区二区三区四区| 美女大bxxxx内射| 久久精品亚洲成在人线a| 久久一区二区三区人妻欧美| 偷拍自拍视频图片免费| 国产成人精品一区在线观看| 任你操任你干精品在线视频| 天天躁日日躁狠狠躁躁欧美av| 国产激情av网站在线观看| av完全免费在线观看av| 久久热久久视频在线观看| 日韩不卡中文在线视频网站| 青青青激情在线观看视频| 2022中文字幕在线| 亚洲欧美久久久久久久久| 一区二区三区久久中文字幕| 中文字幕一区二区三区人妻大片| 国产黄色大片在线免费播放| 伊人日日日草夜夜草| 福利视频广场一区二区| av视屏免费在线播放| 在线免费观看亚洲精品电影| 国产av欧美精品高潮网站| 人人妻人人澡欧美91精品 | 91中文字幕最新合集| 国产视频精品资源网站| 天天做天天干天天操天天射| 国产精彩对白一区二区三区| 91人妻精品久久久久久久网站 | 国产欧美精品不卡在线| 亚洲午夜精品小视频| 亚洲一级美女啪啪啪| 日本性感美女写真视频| 岛国一区二区三区视频在线| 亚洲天堂有码中文字幕视频 | 日韩欧美在线观看不卡一区二区| 天天干天天爱天天色| 精品区一区二区三区四区人妻 | 99re国产在线精品| 亚国产成人精品久久久| 欧美日韩亚洲国产无线码| 中文字幕视频一区二区在线观看 | 久久久久久久久久久久久97| 视频一区二区三区高清在线| 欧美国产亚洲中英文字幕| 91九色porny蝌蚪国产成人| 日本三极片视频网站观看| 在线 中文字幕 一区| 午夜精品一区二区三区城中村| 亚洲护士一区二区三区| 天堂v男人视频在线观看| 中文字幕 亚洲av| 韩国黄色一级二级三级| 91香蕉成人app下载| 天天做天天干天天舔| 国产一线二线三线的区别在哪 | 大胆亚洲av日韩av| 精品美女久久久久久| 视频一区二区在线免费播放| 午夜的视频在线观看| 国产一区二区视频观看| 少妇人妻100系列| 国产精品黄大片在线播放| 久久热这里这里只有精品| 黄色成人在线中文字幕| 女生被男生插的视频网站| 含骚鸡巴玩逼逼视频| 五月色婷婷综合开心网4438| 91www一区二区三区| 亚洲av自拍天堂网| 99热色原网这里只有精品| 中文亚洲欧美日韩无线码| 亚洲国产欧美一区二区三区…| 五十路丰满人妻熟妇| 五十路av熟女松本翔子| 777奇米久久精品一区| 啊啊好慢点插舔我逼啊啊啊视频| 最新欧美一二三视频| 久久艹在线观看视频| 精品久久久久久久久久久久人妻| 老司机免费视频网站在线看| 男大肉棒猛烈插女免费视频 | 中文字幕免费福利视频6| 黄色视频成年人免费观看| 亚洲福利精品视频在线免费观看| 91九色porny蝌蚪国产成人| 中文字幕之无码色多多| 亚洲福利天堂久久久久久| 中文字幕 亚洲av| 国产麻豆精品人妻av| 亚洲1区2区3区精华液| 国产清纯美女al在线| 午夜在线精品偷拍一区二| 国产视频网站国产视频| 亚洲天堂av最新网址| aⅴ精产国品一二三产品| 夜女神免费福利视频| 1区2区3区4区视频在线观看| 色呦呦视频在线观看视频| 中文字幕欧美日韩射射一| 午夜场射精嗯嗯啊啊视频| 扒开让我视频在线观看| 在线观看av2025| 青青草精品在线视频观看| 不卡一不卡二不卡三| 日本女人一级免费片| 19一区二区三区在线播放| 免费黄高清无码国产| 2021年国产精品自拍| 黄片大全在线观看观看| 亚洲熟妇久久无码精品| 91久久国产成人免费网站| 国产综合视频在线看片| 被大鸡吧操的好舒服视频免费| 午夜蜜桃一区二区三区| 国产成人精品久久二区91| 亚洲成人激情视频免费观看了| 国语对白xxxx乱大交| 美女av色播在线播放| 成人免费公开视频无毒| www,久久久,com| 青青色国产视频在线| www,久久久,com| 97资源人妻免费在线视频| 日日操夜夜撸天天干| 亚洲av第国产精品| 欧洲国产成人精品91铁牛tv| 在线免费视频 自拍| 日韩少妇人妻精品无码专区| 国产性感美女福利视频| 99精品亚洲av无码国产另类| 大黑人性xxxxbbbb| 中文字幕之无码色多多| 亚洲高清国产拍青青草原| 在线视频自拍第三页| 含骚鸡巴玩逼逼视频| 美日韩在线视频免费看| 亚洲高清国产自产av| 天天日天天鲁天天操| 日本在线不卡免费视频| 亚洲国产免费av一区二区三区| 天天干天天日天天谢综合156| 欧美中文字幕一区最新网址| 亚洲人妻30pwc| 天堂中文字幕翔田av| 高潮视频在线快速观看国家快速| 日韩人妻在线视频免费| 成年女人免费播放视频| 在线观看国产网站资源| 日本人竟这样玩学生妹| 午夜免费观看精品视频| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 国内资源最丰富的网站| 99亚洲美女一区二区三区| gay gay男男瑟瑟在线网站| 欧美成人精品欧美一级黄色| 9国产精品久久久久老师| av天堂资源最新版在线看| 国产老熟女伦老熟妇ⅹ| 中文字幕 码 在线视频| 老司机免费福利视频网| 性感美女高潮视频久久久 | 久久久久久久亚洲午夜综合福利| 亚洲欧美激情国产综合久久久| 免费在线黄色观看网站| 国产精品大陆在线2019不卡| 午夜场射精嗯嗯啊啊视频| 国产又大又黄免费观看| 夜夜骑夜夜操夜夜奸| 国产精品黄片免费在线观看| 黄色男人的天堂视频| 亚洲精品ww久久久久久| 亚洲综合色在线免费观看| 国产一线二线三线的区别在哪 | 夜夜操,天天操,狠狠操| 久久三久久三久久三久久| 99国内小视频在现欢看| 亚洲一区二区三区久久午夜 | 一区二区三区欧美日韩高清播放| 大黑人性xxxxbbbb| 影音先锋女人av噜噜色| 国产成人小视频在线观看无遮挡| 国产露脸对白在线观看| 熟女少妇激情五十路| 亚洲狠狠婷婷综合久久app| 大香蕉伊人国产在线| 初美沙希中文字幕在线 | 亚洲美女自偷自拍11页| 大香蕉大香蕉在线看| 好吊操视频这里只有精品| 亚洲国产成人av在线一区| 夜色撩人久久7777| 亚洲一级av大片免费观看| 啊用力插好舒服视频| 色综合久久久久久久久中文| 大学生A级毛片免费视频| 老鸭窝在线观看一区| 成人午夜电影在线观看 久久| 欧美精品欧美极品欧美视频| 精品国产污污免费网站入口自 | 一区二区三区另类在线| 特黄老太婆aa毛毛片| 日韩精品激情在线观看| 精品一区二区三区三区色爱| 日本一本午夜在线播放| 偷拍自拍亚洲美腿丝袜| 999九九久久久精品| 国产成人精品亚洲男人的天堂| 白白操白白色在线免费视频 | 偷青青国产精品青青在线观看| 成年人该看的视频黄免费| 黄片色呦呦视频免费看| 亚洲一区二区三区久久午夜| 中文字幕人妻av在线观看| 日本一区精品视频在线观看| 91试看福利一分钟| 蜜桃精品久久久一区二区| 国产午夜福利av导航| 久久午夜夜伦痒痒想咳嗽P| 日本在线一区二区不卡视频| japanese日本熟妇另类| 国产精品大陆在线2019不卡| 欧美日韩激情啪啪啪| 免费在线看的黄网站| 女警官打开双腿沦为性奴| 亚洲av可乐操首页| 噜噜色噜噜噜久色超碰| 最近中文2019年在线看| 东京热男人的av天堂| 9色在线视频免费观看| 亚洲 图片 欧美 图片| 中文亚洲欧美日韩无线码| 中文字幕高清在线免费播放 | 亚洲色偷偷综合亚洲AV伊人| 久久久久只精品国产三级| 天天日天天干天天要| 操人妻嗷嗷叫视频一区二区| 天天做天天干天天操天天射| 青青青青青青青青青青草青青| 亚洲欧美福利在线观看| 夏目彩春在线中文字幕| 99精品视频之69精品视频| 日本韩国免费福利精品| 男人天堂最新地址av| 欧美激情精品在线观看| 国产精品国产三级国产午| 久久精品36亚洲精品束缚| 激情五月婷婷综合色啪| 粉嫩av蜜乳av蜜臀| 在线观看av2025| 亚洲国产最大av综合| 青青色国产视频在线| 欧美香蕉人妻精品一区二区| 色天天天天射天天舔| 天天摸天天日天天操| 午夜精品九一唐人麻豆嫩草成人 | 激情人妻校园春色亚洲欧美| 19一区二区三区在线播放| 91色网站免费在线观看| 性感美女高潮视频久久久| 国产性生活中老年人视频网站| 人妻激情图片视频小说| 亚洲精品国偷自产在线观看蜜桃| 高潮视频在线快速观看国家快速| av网址在线播放大全| 国产九色91在线视频| 亚洲天堂第一页中文字幕| 搞黄色在线免费观看| 国产欧美日韩在线观看不卡| 精品视频一区二区三区四区五区| 亚洲图库另类图片区| 少妇与子乱在线观看| 欧美成人精品在线观看| 在线观看成人国产电影| 丝袜美腿欧美另类 中文字幕| 激情啪啪啪啪一区二区三区| 成人av天堂丝袜在线观看| 99久久超碰人妻国产| 午夜精品亚洲精品五月色| 超碰97人人做人人爱| 在线观看视频网站麻豆| 在线免费观看亚洲精品电影| 女生被男生插的视频网站| 亚洲精品中文字幕下载| 在线观看日韩激情视频| 中文字幕最新久久久| 青青热久免费精品视频在线观看| 99精品免费观看视频| 男人操女人的逼免费视频| 久久久久久久久久一区二区三区| 久久久久久99国产精品| 人人爽亚洲av人人爽av| 欧美一区二区三区激情啪啪啪 | 日本高清成人一区二区三区| 亚洲av色图18p| 国产之丝袜脚在线一区二区三区| 免费无毒热热热热热热久| 特黄老太婆aa毛毛片| 亚国产成人精品久久久| 人妻久久久精品69系列| 97精品综合久久在线| 国产九色91在线视频| 精品一区二区三区在线观看| 黄色大片免费观看网站| 午夜dv内射一区区| 91亚洲手机在线视频播放| 大陆胖女人与丈夫操b国语高清| 这里有精品成人国产99| 国产黄色片在线收看| 欧美精品 日韩国产| 色在线观看视频免费的| 免费av岛国天堂网站| 黄网十四区丁香社区激情五月天| 欧美精品一二三视频| 又粗又长 明星操逼小视频| 大香蕉大香蕉大香蕉大香蕉大香蕉 | 家庭女教师中文字幕在线播放| 亚洲精品麻豆免费在线观看| 在线观看的a站 最新| 国产美女午夜福利久久| 2022国产精品视频| 青青青国产片免费观看视频| 中文字幕人妻三级在线观看| 9l人妻人人爽人人爽| 亚洲av无硬久久精品蜜桃| 水蜜桃一区二区三区在线观看视频| 欧美精品欧美极品欧美视频 | 亚洲av日韩精品久久久| 99婷婷在线观看视频| 一区二区三区在线视频福利| 国产成人午夜精品福利| 婷婷色国产黑丝少妇勾搭AV | 天天色天天操天天透| 老司机福利精品视频在线| 99精品国产自在现线观看| 亚洲精品午夜久久久久| 18禁网站一区二区三区四区| 自拍偷拍日韩欧美一区二区| 久久久噜噜噜久久熟女av| 欧美黑人性暴力猛交喷水| 日韩近亲视频在线观看| 高清成人av一区三区| 午夜精品亚洲精品五月色| 日本韩国在线观看一区二区| 亚洲蜜臀av一区二区三区九色 | 午夜青青草原网在线观看| 人妻少妇亚洲精品中文字幕| 91传媒一区二区三区| 欧美成人综合色在线噜噜| 色吉吉影音天天干天天操| 免费av岛国天堂网站| 欧美偷拍亚洲一区二区| av在线观看网址av| 美女小视频网站在线| 欧洲黄页网免费观看| 一色桃子人妻一区二区三区| 97国产在线av精品| 最近中文字幕国产在线| 亚洲伊人色一综合网| 久久尻中国美女视频| 操人妻嗷嗷叫视频一区二区| 中文字幕1卡1区2区3区| 日韩精品啪啪视频一道免费| 天天射夜夜操狠狠干| 黄色录像鸡巴插进去| 欧美aa一级一区三区四区| 91精品综合久久久久3d动漫| 最新中文字幕乱码在线| 美女av色播在线播放| free性日本少妇| 国产福利小视频大全| 视频 一区二区在线观看| 美女在线观看日本亚洲一区| 快插进小逼里大鸡吧视频| 精品国产乱码一区二区三区乱| 午夜精品久久久久久99热| 欧美老妇精品另类不卡片| 精品老妇女久久9g国产| 国产免费av一区二区凹凸四季| 国产清纯美女al在线| 麻豆性色视频在线观看| 人人超碰国字幕观看97| 国产精选一区在线播放| 久久精品亚洲成在人线a| 亚洲人妻国产精品综合| 日韩影片一区二区三区不卡免费| www骚国产精品视频| 国产成人精品久久二区91| 做爰视频毛片下载蜜桃视频1| 日本丰满熟妇BBXBBXHD| 天天做天天干天天操天天射| 午夜激情久久不卡一区二区 | 首之国产AV医生和护士小芳| 欧美老鸡巴日小嫩逼| 激情啪啪啪啪一区二区三区| 岛国黄色大片在线观看| 亚洲 中文 自拍 另类 欧美| 人人爽亚洲av人人爽av| 2022天天干天天操| 干逼又爽又黄又免费的视频| 18禁无翼鸟成人在线| 18禁污污污app下载| 中文字幕在线观看极品视频| 天天艹天天干天天操| 亚洲一区av中文字幕在线观看| 一级黄色av在线观看| 啪啪啪啪啪啪啪啪av| 国产白嫩美女一区二区| 久久久久久国产精品| 亚洲欧美国产麻豆综合| 男人的网址你懂的亚洲欧洲av| 91久久国产成人免费网站| 男人和女人激情视频| 国产亚洲成人免费在线观看| 国产精品国产三级麻豆| 成年人免费看在线视频| 老司机你懂得福利视频| 国产精品午夜国产小视频| 在线观看免费岛国av| 又大又湿又爽又紧A视频| 操日韩美女视频在线免费看| 青青青视频手机在线观看| 东京热男人的av天堂| 日本欧美视频在线观看三区| v888av在线观看视频| 伊人开心婷婷国产av| 日本最新一二三区不卡在线| 揄拍成人国产精品免费看视频| 在线播放一区二区三区Av无码| 五月激情婷婷久久综合网| 欧美日韩人妻久久精品高清国产| 国产高清精品极品美女| 色噜噜噜噜18禁止观看| 亚欧在线视频你懂的| 啪啪啪操人视频在线播放| 国产刺激激情美女网站| av手机在线免费观看日韩av| 三上悠亚和黑人665番号| 被大鸡吧操的好舒服视频免费| 激情人妻校园春色亚洲欧美| 精品人妻每日一部精品| 日本美女成人在线视频| 美味人妻2在线播放| 亚洲国产成人最新资源| 亚洲一区制服丝袜美腿| 好吊视频—区二区三区| 亚洲 色图 偷拍 欧美| 91亚洲精品干熟女蜜桃频道| 日本av在线一区二区三区| 久久麻豆亚洲精品av| 2022精品久久久久久中文字幕| 国产美女一区在线观看| 欧美80老妇人性视频| 自拍偷拍一区二区三区图片| aⅴ五十路av熟女中出| av网站色偷偷婷婷网男人的天堂| 免费看高清av的网站| wwwxxx一级黄色片| 男生舔女生逼逼的视频| 777奇米久久精品一区| 18禁免费av网站| 9国产精品久久久久老师| 亚洲国产最大av综合| 亚洲综合在线视频可播放| 欧美成人综合视频一区二区| 91精品资源免费观看| 色吉吉影音天天干天天操| 日韩三级黄色片网站| 护士特殊服务久久久久久久| 色花堂在线av中文字幕九九| 97人妻夜夜爽二区欧美极品| 天天日天天干天天爱| 99av国产精品欲麻豆| 天天日天天天天天天天天天天| 不卡一区一区三区在线| 午夜免费体验区在线观看| 99热99re在线播放| 激情图片日韩欧美人妻| 免费一级黄色av网站| 涩爱综合久久五月蜜臀| 熟女人妻三十路四十路人妻斩| 都市激情校园春色狠狠| av黄色成人在线观看| 东游记中文字幕版哪里可以看到| 高清一区二区欧美系列| 抽查舔水白紧大视频| 自拍偷拍亚洲欧美在线视频| 亚洲激情av一区二区| 美女在线观看日本亚洲一区| 99人妻视频免费在线| 护士小嫩嫩又紧又爽20p| 青青社区2国产视频| 亚洲最大黄了色网站| 欧洲亚洲欧美日韩综合| 2021国产一区二区| 80电影天堂网官网| 91‖亚洲‖国产熟女| 日本少妇精品免费视频| 99热国产精品666| 日韩午夜福利精品试看| 国产日韩精品电影7777| 好吊视频—区二区三区| 99久久99久国产黄毛片| 动漫黑丝美女的鸡巴| 中国无遮挡白丝袜二区精品 | 熟女在线视频一区二区三区| 青草久久视频在线观看| 午夜美女少妇福利视频| 天天干天天插天天谢| 青青在线视频性感少妇和隔壁黑丝| 中文字幕在线乱码一区二区| 国产麻豆国语对白露脸剧情 | 亚洲午夜福利中文乱码字幕| 国产亚洲四十路五十路| 欧亚日韩一区二区三区观看视频| 亚洲av成人网在线观看| 亚洲美女美妇久久字幕组| 91色秘乱一区二区三区| 精品高潮呻吟久久av| 激情图片日韩欧美人妻| 中文字幕欧美日韩射射一| 一色桃子久久精品亚洲 | 在线视频精品你懂的| 大尺度激情四射网站| 青青草原色片网站在线观看| 国产刺激激情美女网站| 色综合天天综合网国产成人| 天天摸天天干天天操科普| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 成人高清在线观看视频| 婷婷久久一区二区字幕网址你懂得| 精品一线二线三线日本| 9l人妻人人爽人人爽| 涩爱综合久久五月蜜臀| 亚洲国产欧美一区二区三区…| 日本精品一区二区三区在线视频。| 九九热99视频在线观看97| 传媒在线播放国产精品一区| 在线国产日韩欧美视频| 亚洲精品乱码久久久本| 美女操逼免费短视频下载链接 | 国产精品黄色的av| 欧美成人综合视频一区二区| 红杏久久av人妻一区| 久草视频福利在线首页| 成年人的在线免费视频| 中文字幕最新久久久| 国产麻豆剧果冻传媒app| 六月婷婷激情一区二区三区| 国产精品久久久久久美女校花| 99re6热在线精品| 午夜dv内射一区区| 欧美成人一二三在线网| 亚洲av琪琪男人的天堂| 插小穴高清无码中文字幕| yy6080国产在线视频| 亚洲天堂第一页中文字幕| 欧洲国产成人精品91铁牛tv | 中文字幕一区二区亚洲一区| 91av精品视频在线| 大香蕉伊人国产在线| 日本高清撒尿pissing| 中英文字幕av一区| 2018在线福利视频| 国产精品视频欧美一区二区| 欧美地区一二三专区| 最新中文字幕乱码在线| 天天干天天操天天玩天天射| 3D动漫精品啪啪一区二区下载| 最新97国产在线视频| 在线视频这里只有精品自拍| 国产 在线 免费 精品| 播放日本一区二区三区电影| 任我爽精品视频在线播放| 日韩影片一区二区三区不卡免费| 丰满的子国产在线观看| 又色又爽又黄又刺激av网站| 青青操免费日综合视频观看| 日韩少妇人妻精品无码专区| 91中文字幕最新合集| 国产精品人妻熟女毛片av久| 国产aⅴ一线在线观看| 第一福利视频在线观看| 国产成人无码精品久久久电影| 视频啪啪啪免费观看| av成人在线观看一区| 中文字幕日韩精品就在这里| 欧美日韩在线精品一区二区三| 久久精品久久精品亚洲人| 黄色成年网站午夜在线观看| 亚洲av成人免费网站| 黑人进入丰满少妇视频| 国产亚洲精品欧洲在线观看| 免费手机黄页网址大全| 边摸边做超爽毛片18禁色戒| 狍和女人的王色毛片| 午夜极品美女福利视频| 亚洲国产40页第21页| 亚洲欧洲一区二区在线观看| 青青草成人福利电影| 亚洲精品av在线观看| 国产不卡av在线免费| 日本免费一级黄色录像| 亚洲美女高潮喷浆视频| 亚洲久久午夜av一区二区| 快插进小逼里大鸡吧视频| 久久综合老鸭窝色综合久久| 五十路老熟女码av| 色在线观看视频免费的| 午夜福利资源综合激情午夜福利资| 专门看国产熟妇的网站| 扒开让我视频在线观看| 亚洲一区二区三区精品视频在线| 清纯美女在线观看国产| av中文在线天堂精品| 啪啪啪18禁一区二区三区| av天堂中文免费在线| 久久综合老鸭窝色综合久久 | 中文字幕一区二区自拍| 人妻少妇性色欲欧美日韩| 午夜青青草原网在线观看| 国产成人无码精品久久久电影| 日本少妇人妻xxxxx18| 老司机午夜精品视频资源| 精品美女久久久久久| 日韩a级精品一区二区| av新中文天堂在线网址| 2021天天色天天干| 国产精品一区二区久久久av| 日韩美女搞黄视频免费| 欧美精品资源在线观看| 青青青国产片免费观看视频| 免费看高清av的网站| 亚洲欧美另类自拍偷拍色图| 午夜在线一区二区免费| 免费手机黄页网址大全| 色综合天天综合网国产成人| 亚洲成人国产av在线| 国产福利在线视频一区| 激情国产小视频在线| 青青色国产视频在线| 91试看福利一分钟| 手机看片福利盒子日韩在线播放| 80电影天堂网官网| 久久久久久9999久久久久| 亚洲av无硬久久精品蜜桃| 日本午夜久久女同精女女| 99久久中文字幕一本人| 在线成人日韩av电影| 欧美日本在线观看一区二区| 成年人黄色片免费网站| 日本裸体熟妇区二区欧美| 亚洲码av无色中文| 丁香花免费在线观看中文字幕| 国产变态另类在线观看| 日韩av中文在线免费观看| 日本人妻欲求不满中文字幕| 97资源人妻免费在线视频| caoporn蜜桃视频| 国产精品黄片免费在线观看| 在线免费观看日本片| 亚洲欧美另类自拍偷拍色图| 九九热99视频在线观看97| 岛国一区二区三区视频在线| 92福利视频午夜1000看| 综合色区亚洲熟妇shxstz| 中文字幕亚洲久久久| 天天日天天做天天日天天做| 日韩欧美一级aa大片| 国产三级影院在线观看| 换爱交换乱高清大片| 98视频精品在线观看| 精品老妇女久久9g国产| 91中文字幕最新合集| 日韩欧美一级aa大片| 天堂va蜜桃一区入口| 一区二区三区麻豆福利视频| 自拍偷拍亚洲欧美在线视频| 久久久久久99国产精品| 中文字幕在线永久免费播放| 欧美亚洲中文字幕一区二区三区 | 亚洲欧美自拍另类图片| 久草福利电影在线观看| 91国内精品久久久久精品一| 韩国三级aaaaa高清视频| 日本美女性生活一级片| 99国产精品窥熟女精品| 91成人精品亚洲国产| 无码中文字幕波多野不卡| 欧美中文字幕一区最新网址| 中文字幕熟女人妻久久久| 狠狠嗨日韩综合久久| 91精品免费久久久久久| 日本人竟这样玩学生妹| 特大黑人巨大xxxx| 人人爱人人妻人人澡39| 亚洲一级特黄特黄黄色录像片| 福利视频一区二区三区筱慧| 最近中文字幕国产在线| 红桃av成人在线观看| 新97超碰在线观看| 最新97国产在线视频| 一二三中文乱码亚洲乱码one | 黑人巨大精品欧美视频| 天天日天天做天天日天天做| 青青青青爽手机在线| 老司机你懂得福利视频| 国产精品自拍偷拍a| 东游记中文字幕版哪里可以看到| 超碰中文字幕免费观看| 国产视频网站国产视频| 欧美专区第八页一区在线播放| 青青草亚洲国产精品视频| 亚洲欧美福利在线观看| 五十路息与子猛烈交尾视频 | 亚洲国产香蕉视频在线播放| 色婷婷综合激情五月免费观看| av日韩在线免费播放| 夜色撩人久久7777| 亚洲国产第一页在线观看| 十八禁在线观看地址免费| 硬鸡巴动态操女人逼视频| 成年人午夜黄片视频资源| 亚洲 清纯 国产com| 韩国爱爱视频中文字幕| 在线亚洲天堂色播av电影| 自拍偷拍vs一区二区三区| 五十路熟女人妻一区二区9933| 欧美一区二区三区久久久aaa| 日韩美av高清在线| 91精品综合久久久久3d动漫| 日本后入视频在线观看| 成年午夜免费无码区| 这里有精品成人国产99| 99视频精品全部15| 欧亚乱色一区二区三区| 国产精品久久久久久久久福交 | 丝袜长腿第一页在线| 欧美特色aaa大片| 午夜婷婷在线观看视频| 老师让我插进去69AV| 国产熟妇乱妇熟色T区| 中文字幕日韩无敌亚洲精品 | 午夜精品久久久久麻豆影视| 97人妻无码AV碰碰视频| 水蜜桃一区二区三区在线观看视频| 欧美性受xx黑人性猛交| 日本黄色特一级视频| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 天天日天天操天天摸天天舔| 99精品国自产在线人| 99精品视频在线观看免费播放| 美女 午夜 在线视频| 五月婷婷在线观看视频免费| 在线观看免费视频网| 精品黑人巨大在线一区| 97色视频在线观看| 国产亚洲视频在线二区| 欧美日韩人妻久久精品高清国产| nagger可以指黑人吗| 黑人性生活视频免费看| 黄色片年轻人在线观看| 国产三级精品三级在线不卡| 91桃色成人网络在线观看| 亚洲一级av无码一级久久精品| 熟女人妻一区二区精品视频| av破解版在线观看| 亚洲综合乱码一区二区| 日本人妻欲求不满中文字幕| 三上悠亚和黑人665番号| 自拍偷拍日韩欧美亚洲| 中文字幕高清免费在线人妻| 国产成人精品av网站| 中国产一级黄片免费视频播放| 精品视频中文字幕在线播放| 日韩成人性色生活片| 少妇人妻二三区视频| 日韩亚洲高清在线观看| 自拍偷区二区三区麻豆| 国产亚洲视频在线二区| 国产成人自拍视频播放| 91 亚洲视频在线观看| 国产va精品免费观看| 男生舔女生逼逼的视频| 日韩中文字幕在线播放第二页| 久久久久久久精品老熟妇| 91av中文视频在线| 亚洲精品在线资源站| 久久久久久久久久久久久97| 国产高清精品极品美女| 欧美另类一区二区视频| 成人国产影院在线观看| 国产精品自拍偷拍a| 亚洲va国产va欧美精品88| 久久久久久97三级| 色呦呦视频在线观看视频| 国产在线观看免费人成短视频| 首之国产AV医生和护士小芳| 亚洲免费va在线播放| 在线国产精品一区二区三区| 91老师蜜桃臀大屁股| 精产国品久久一二三产区区别| 欧美成人精品在线观看| 97超碰免费在线视频| 亚洲一区二区三区在线高清| 一区国内二区日韩三区欧美| 国产成人自拍视频在线免费观看| 久久久久久99国产精品| 亚洲一区自拍高清免费视频| 夏目彩春在线中文字幕| 欧美80老妇人性视频| 色婷婷六月亚洲综合香蕉| 亚洲av自拍天堂网| 日美女屁股黄邑视频| 91小伙伴中女熟女高潮| 国产午夜亚洲精品麻豆| 国产精品久久久久久美女校花| 高潮视频在线快速观看国家快速| 中文字幕日韩精品日本| 免费在线黄色观看网站| 日本男女操逼视频免费看| 欧美老鸡巴日小嫩逼| 午夜精品一区二区三区福利视频| 日比视频老公慢点好舒服啊| 91精品国产观看免费| 香蕉aⅴ一区二区三区| 久久永久免费精品人妻专区| 5528327男人天堂| 好男人视频在线免费观看网站| 亚洲在线免费h观看网站| 欧美激情电影免费在线| 国产chinesehd精品麻豆| 久久久久久久久久久久久97| 青青青青青手机视频| 538精品在线观看视频| 午夜精品九一唐人麻豆嫩草成人 | 欧美特色aaa大片| 性欧美日本大妈母与子| 国产成人无码精品久久久电影| 91av中文视频在线| 91香蕉成人app下载| 亚洲欧美自拍另类图片| 日韩视频一区二区免费观看| 日本一二三区不卡无| 97青青青手机在线视频| 人妻少妇一区二区三区蜜桃| 狠狠躁狠狠爱网站视频| 黑人变态深video特大巨大| 欧美亚洲自偷自拍 在线| 色婷婷综合激情五月免费观看 | 熟妇一区二区三区高清版| 亚洲伊人久久精品影院一美女洗澡| 91自产国产精品视频| ka0ri在线视频| 欧美一区二区三区激情啪啪啪| 人妻少妇亚洲精品中文字幕| sejizz在线视频| 精品国产午夜视频一区二区| 中文字幕在线乱码一区二区| 欧美日韩熟女一区二区三区| 社区自拍揄拍尻屁你懂的| 成人在线欧美日韩国产| 后入美女人妻高清在线| 人人妻人人爱人人草| 日本人妻精品久久久久久| 熟女俱乐部一二三区| av在线资源中文字幕| 亚洲第一黄色在线观看 | 日韩激情文学在线视频| 搡老妇人老女人老熟女| 一区二区三区四区中文| 亚洲一区二区激情在线| 人妻最新视频在线免费观看| 99精品免费观看视频| 中文字幕第一页国产在线| 高清成人av一区三区| 亚洲av第国产精品| 国产精品欧美日韩区二区| 亚洲成人黄色一区二区三区| 久久久久久久久久性潮| 91啪国自产中文字幕在线| 97成人免费在线观看网站| okirakuhuhu在线观看| 欧美精品欧美极品欧美视频| 国产超码片内射在线| 人人超碰国字幕观看97| 91‖亚洲‖国产熟女| 青青热久免费精品视频在线观看 | 和邻居少妇愉情中文字幕| 国产一线二线三线的区别在哪| 国产成人无码精品久久久电影| 在线观看欧美黄片一区二区三区| 国产麻豆国语对白露脸剧情| 2021年国产精品自拍| 日本18禁久久久久久| 手机看片福利盒子日韩在线播放| 中文字幕在线一区精品| 国产成人精品福利短视频| 国产成人自拍视频播放| 大尺度激情四射网站| 亚洲一级av大片免费观看| 五月天中文字幕内射| 免费在线播放a级片| 在线国产精品一区二区三区| 亚洲成人激情视频免费观看了 | 女警官打开双腿沦为性奴| 91精品国产观看免费| 粗大的内捧猛烈进出爽大牛汉子| 福利视频广场一区二区| 亚洲成人国产综合一区| 日本一区精品视频在线观看| 97香蕉碰碰人妻国产樱花| 99精品国产aⅴ在线观看| 国产精品精品精品999| 人人妻人人爽人人添夜| 中文字幕一区二区人妻电影冢本| 欧美在线精品一区二区三区视频 | 最新欧美一二三视频 | 91av精品视频在线| 经典亚洲伊人第一页| 91国产资源在线视频| 大黑人性xxxxbbbb| 在线新三级黄伊人网| 91免费放福利在线观看| 欧美日本在线视频一区| 91小伙伴中女熟女高潮| 天天干天天搞天天摸| 中文字幕+中文字幕| 午夜青青草原网在线观看| huangse网站在线观看| 欧美交性又色又爽又黄麻豆| 中文字日产幕乱六区蜜桃| 中文字幕在线观看极品视频| 亚洲综合另类欧美久久| 亚洲中文字字幕乱码| 国产av一区2区3区| 免费手机黄页网址大全| av视网站在线观看| 韩国三级aaaaa高清视频| 亚洲国产精品黑丝美女| 中文字幕无码一区二区免费| 成人亚洲精品国产精品| 3344免费偷拍视频| 欧美精品久久久久久影院| 免费黄页网站4188| 亚洲av男人的天堂你懂的| 白嫩白嫩美女极品国产在线观看| 在线国产日韩欧美视频| av中文字幕在线导航| 97精品视频在线观看| 久久99久久99精品影院| 天堂av在线播放免费| 天天插天天色天天日| 激情小视频国产在线| 97人妻夜夜爽二区欧美极品| 999热精品视频在线| 亚洲国产成人在线一区| 91综合久久亚洲综合| 哥哥姐姐综合激情小说| 午夜免费体验区在线观看| 91国内精品自线在拍白富美| 亚洲1069综合男同| 熟女少妇激情五十路| 五月天色婷婷在线观看视频免费| 亚洲一区二区三区精品乱码| 午夜精品在线视频一区| 午夜毛片不卡免费观看视频| 桃色视频在线观看一区二区| 在线观看免费av网址大全| 色天天天天射天天舔| 国产+亚洲+欧美+另类| 日本人妻少妇18—xx| 天天干天天操天天爽天天摸| 扒开让我视频在线观看| 抽查舔水白紧大视频| 在线免费观看亚洲精品电影| 青青草人人妻人人妻| 超碰公开大香蕉97| 天天操天天弄天天射| 人妻久久久精品69系列| 欧美在线精品一区二区三区视频| 伊人网中文字幕在线视频| 午夜dv内射一区区| 瑟瑟视频在线观看免费视频| 91九色porny国产在线| 久久亚洲天堂中文对白| 精品黑人巨大在线一区| 动漫av网站18禁| 中文字幕国产专区欧美激情| caoporm超碰国产| 日本性感美女三级视频| 小泽玛利亚视频在线观看| 中文字幕亚洲中文字幕| 色在线观看视频免费的| 亚洲精品无码色午夜福利理论片| 国产一区二区在线欧美| 天堂av狠狠操蜜桃| avjpm亚洲伊人久久| 国产污污污污网站在线| 欧美日韩国产一区二区三区三州| 亚洲护士一区二区三区| 中国黄片视频一区91| 偷拍自拍亚洲美腿丝袜| 男人的天堂在线黄色| 绝顶痉挛大潮喷高潮无码 | 在线免费91激情四射 | 丰满的继坶3中文在线观看| 最近的中文字幕在线mv视频| 一区二区三区视频,福利一区二区| 日噜噜噜夜夜噜噜噜天天噜噜噜| 久草视频中文字幕在线观看| 极品粉嫩小泬白浆20p主播| 日韩美av高清在线| 国产欧美精品一区二区高清| 无忧传媒在线观看视频| 密臀av一区在线观看| 99精品久久久久久久91蜜桃| yellow在线播放av啊啊啊 | 18禁美女无遮挡免费| 欧美va不卡视频在线观看| 欧美激情精品在线观看| 欧美另类重口味极品在线观看| 91人妻人人做人人爽在线| 福利午夜视频在线合集| 夜夜骑夜夜操夜夜奸| 福利视频网久久91| 日韩亚国产欧美三级涩爱| 日本福利午夜电影在线观看| 欧美特色aaa大片| 免费黄高清无码国产| 人妻久久久精品69系列| 欧美第一页在线免费观看视频| 搡老妇人老女人老熟女| 综合色区亚洲熟妇shxstz| 成人av免费不卡在线观看| 国产九色91在线观看精品| 天天通天天透天天插| 超pen在线观看视频公开97| 国产福利在线视频一区| 国产性感美女福利视频| 国产乱子伦精品视频潮优女| 色偷偷伊人大杳蕉综合网| 久久www免费人成一看片| 色吉吉影音天天干天天操| 欧洲亚洲欧美日韩综合| 91天堂精品一区二区| 2022国产综合在线干| 免费大片在线观看视频网站| 亚洲的电影一区二区三区 | 中文字幕日韩精品就在这里| 最新97国产在线视频| 青青青青青操视频在线观看| 国产精品自偷自拍啪啪啪| 天天躁日日躁狠狠躁躁欧美av | 一级黄色av在线观看| 亚洲精品欧美日韩在线播放| 精品久久婷婷免费视频| 在线免费观看日本伦理| 久久久久五月天丁香社区| 999九九久久久精品| 玩弄人妻熟妇性色av少妇| 在线视频免费观看网| 欧美成一区二区三区四区| 视频 国产 精品 熟女 | 国产精品久久久久久美女校花| 免费黄色成人午夜在线网站| 91久久精品色伊人6882| 少妇人妻真实精品视频| 亚洲一区二区三区久久午夜| 欧洲国产成人精品91铁牛tv| 色综合色综合色综合色| 国产 在线 免费 精品| 蜜桃臀av蜜桃臀av| 18禁无翼鸟成人在线 | 日本美女性生活一级片| 神马午夜在线观看视频| 中国熟女@视频91| 免费高清自慰一区二区三区网站| 免费手机黄页网址大全| 最新91精品视频在线| 75国产综合在线视频| 国产欧美精品一区二区高清| 早川濑里奈av黑人番号| 亚洲成人激情视频免费观看了| 亚洲福利午夜久久久精品电影网 | 国产97视频在线精品| 亚洲av一妻不如妾| 黄片大全在线观看观看| 亚洲av自拍天堂网| 超碰公开大香蕉97| 边摸边做超爽毛片18禁色戒| 天天操天天操天天碰| 夏目彩春在线中文字幕| 国产精品久久久久久美女校花| 欧美精品久久久久久影院| 综合一区二区三区蜜臀| 亚洲老熟妇日本老妇| 天天干天天插天天谢| 55夜色66夜色国产精品站| 99久久超碰人妻国产| 欧美精品 日韩国产| 亚洲国产精品黑丝美女| 在线免费91激情四射| 日韩精品电影亚洲一区| 亚洲va国产va欧美精品88| 日本特级片中文字幕| 在线免费观看亚洲精品电影| 久久永久免费精品人妻专区| 日韩精品中文字幕在线| 一区二区三区麻豆福利视频| 久久久久久久久久一区二区三区 | 干逼又爽又黄又免费的视频| 欧美成人综合视频一区二区 | 视频在线免费观看你懂得| 日本丰满熟妇大屁股久久| 国产精品一区二区av国| 在线观看的a站 最新| 亚洲国产精品美女在线观看| 三级黄色亚洲成人av| 中文字幕在线视频一区二区三区 | 国产在线一区二区三区麻酥酥| 婷婷综合蜜桃av在线| 美女福利视频导航网站| av一本二本在线观看| 全国亚洲男人的天堂| 国产精品视频男人的天堂| 性欧美激情久久久久久久| 福利视频网久久91| 亚洲国产欧美国产综合在线| 日本最新一二三区不卡在线| 2021天天色天天干| 黄工厂精品视频在线观看| 国产福利小视频免费观看| 麻豆性色视频在线观看| 大白屁股精品视频国产| 天堂av狠狠操蜜桃| 亚洲熟妇久久无码精品| 国产亚洲精品品视频在线| 国产V亚洲V天堂无码欠欠| 91久久国产成人免费网站| 亚洲2021av天堂| 综合精品久久久久97| 99精品免费久久久久久久久a| 97超碰国语国产97超碰| 天天摸天天日天天操| 丝袜亚洲另类欧美变态| 色综合色综合色综合色| 亚洲一区二区三区久久午夜| 久久久麻豆精亚洲av麻花| 国产亚洲国产av网站在线| 亚洲av极品精品在线观看| 中文字幕高清在线免费播放| 夜夜嗨av蜜臀av| 亚洲狠狠婷婷综合久久app| 在线成人日韩av电影| 久草视频福利在线首页| 欧美在线一二三视频| 亚国产成人精品久久久| 硬鸡巴动态操女人逼视频| 黄色片一级美女黄色片| 蜜臀成人av在线播放| 国产高清97在线观看视频| 国产在线自在拍91国语自产精品| 女同性ⅹxx女同h偷拍| 丰满少妇人妻xxxxx| 青草久久视频在线观看| 久久精品国产23696| 777奇米久久精品一区| 日韩激情文学在线视频| 粉嫩av懂色av蜜臀av | 自拍 日韩 欧美激情| 97超碰国语国产97超碰| 初美沙希中文字幕在线 | 99的爱精品免费视频| 老司机福利精品视频在线| 国产福利小视频二区| 操操网操操伊剧情片中文字幕网| 88成人免费av网站| 国产真实灌醉下药美女av福利| 天堂va蜜桃一区入口| 久久午夜夜伦痒痒想咳嗽P| 国产精品伦理片一区二区| 中文字幕1卡1区2区3区| 日韩成人性色生活片| 亚洲国产精品久久久久蜜桃| 天天插天天色天天日| 亚洲最大黄了色网站| 欧亚乱色一区二区三区| 在线新三级黄伊人网| 最新的中文字幕 亚洲| 四虎永久在线精品免费区二区| 黄网十四区丁香社区激情五月天| 任你操任你干精品在线视频| 天天日天天鲁天天操| 国产精品成人xxxx| 最新国产精品网址在线观看| 五十路熟女人妻一区二| 黄色片黄色片wyaa| 国产又粗又猛又爽又黄的视频美国 | 男人的天堂在线黄色| 天堂av在线最新版在线| 亚洲高清国产拍青青草原| 国产综合精品久久久久蜜臀| 免费观看丰满少妇做受| 精品一区二区三四区| 青青热久免费精品视频在线观看| 中国老熟女偷拍第一页| 国产一区二区视频观看| 亚洲高清国产一区二区三区| 成人亚洲国产综合精品| 亚洲天堂精品久久久| 欧美精品激情在线最新观看视频| 午夜在线观看一区视频| 欧美亚洲一二三区蜜臀| 久精品人妻一区二区三区 | 大胆亚洲av日韩av| 日韩欧美一级黄片亚洲| 含骚鸡巴玩逼逼视频| 国产中文精品在线观看| 午夜精品亚洲精品五月色| 日韩欧美一级aa大片| 在线国产日韩欧美视频| 亚洲av无硬久久精品蜜桃| 色婷婷综合激情五月免费观看 | 偷拍自拍亚洲美腿丝袜| 中文字幕第一页国产在线| 欧美另类重口味极品在线观看| 91九色国产熟女一区二区| 天堂av狠狠操蜜桃| 久久久久久性虐视频| 日韩美女精品视频在线观看网站 | 亚洲国产免费av一区二区三区 | 国产伊人免费在线播放| 午夜福利资源综合激情午夜福利资| 岛国青草视频在线观看| 久久综合老鸭窝色综合久久| 男生舔女生逼逼视频| 中文字幕日韩无敌亚洲精品 | 久久久久久99国产精品| 国产高清97在线观看视频| 最新国产精品网址在线观看| 天天插天天狠天天操| 成人sm视频在线观看| 亚洲国产免费av一区二区三区| 99一区二区在线观看| av视屏免费在线播放| 欧美va不卡视频在线观看| 天天夜天天日天天日| 韩国黄色一级二级三级| 9色精品视频在线观看| 成熟熟女国产精品一区| 欧美在线偷拍视频免费看| 性感美女高潮视频久久久| 超pen在线观看视频公开97| 秋霞午夜av福利经典影视| av中文字幕在线观看第三页| 黄色成年网站午夜在线观看| 午夜极品美女福利视频| 91免费黄片可看视频 | 国产精品视频欧美一区二区 | 91桃色成人网络在线观看| 日韩欧美一级aa大片| 国产日韩精品一二三区久久久 | 天天日天天操天天摸天天舔| 91精品国产91青青碰| 亚洲丝袜老师诱惑在线观看| 在线播放一区二区三区Av无码| 少妇系列一区二区三区视频| 91成人精品亚洲国产| 蜜桃臀av蜜桃臀av| 国产亚州色婷婷久久99精品| 成人资源在线观看免费官网| 手机看片福利盒子日韩在线播放| 91在线免费观看成人| 欧美色婷婷综合在线| 日本高清成人一区二区三区| 最新日韩av传媒在线| 青娱乐蜜桃臀av色| 视频一区二区在线免费播放| 日韩在线视频观看有码在线| 天天日天天舔天天射进去| 久草电影免费在线观看| 亚洲天天干 夜夜操| 亚欧在线视频你懂的| 98视频精品在线观看| 婷婷色国产黑丝少妇勾搭AV| 97超碰人人搞人人| 啊啊好大好爽啊啊操我啊啊视频| 欧美麻豆av在线播放| 精品国产亚洲av一淫| 天天日夜夜干天天操| 又大又湿又爽又紧A视频| 任你操视频免费在线观看| 日本丰满熟妇大屁股久久| 国产大学生援交正在播放| 国产chinesehd精品麻豆| 午夜场射精嗯嗯啊啊视频| 偷拍3456eee| 中文字幕第三十八页久久| 日本人妻精品久久久久久| 亚洲高清一区二区三区视频在线| 国产精品国产精品一区二区| 2022中文字幕在线| 久久久极品久久蜜桃| 日本啪啪啪啪啪啪啪| 护士特殊服务久久久久久久| 91九色porny国产蝌蚪视频| 男女啪啪视频免费在线观看| 中文字幕av一区在线观看| 不卡一不卡二不卡三| 国产超码片内射在线| 91精品国产黑色丝袜| 久久久人妻一区二区| 最近中文字幕国产在线| 端庄人妻堕落挣扎沉沦| 综合激情网激情五月天| 三级av中文字幕在线观看| 夜夜嗨av一区二区三区中文字幕| 久草视频在线免播放| 一区二区视频在线观看免费观看 | 天天日天天添天天爽| 四川乱子伦视频国产vip| 久久久久久9999久久久久| 亚洲人妻30pwc| 国际av大片在线免费观看| 久久综合老鸭窝色综合久久| 免费在线播放a级片| av中文字幕在线观看第三页| 五十路丰满人妻熟妇| 黄色大片免费观看网站| 100%美女蜜桃视频| 91精品国产黑色丝袜| 大鸡吧插入女阴道黄色片| 欲乱人妻少妇在线视频裸| 免费在线观看污污视频网站| 欧美日本在线观看一区二区| 干逼又爽又黄又免费的视频| 日本少妇人妻xxxxxhd| av中文字幕在线导航| 黑人巨大的吊bdsm| 97瑟瑟超碰在线香蕉| 亚洲天天干 夜夜操| 国产精品自拍偷拍a| 人妻丝袜榨强中文字幕| 中文人妻AV久久人妻水| 中文字幕av第1页中文字幕| 国产卡一卡二卡三乱码手机| 日韩av有码一区二区三区4| 国产综合高清在线观看| 国产精品久久久黄网站| 六月婷婷激情一区二区三区| 97国产精品97久久| 欧美日韩v中文在线| 1000部国产精品成人观看视频| 国产在线观看黄色视频| 中国无遮挡白丝袜二区精品| 人妻凌辱欧美丰满熟妇| 亚洲欧美自拍另类图片| 九九视频在线精品播放| 欧美成人猛片aaaaaaa| 国产福利小视频免费观看| 久久精品亚洲国产av香蕉| 天天插天天狠天天操| jiuse91九色视频| 精品美女在线观看视频在线观看| 国产精品一二三不卡带免费视频| 337p日本大胆欧美人| 午夜婷婷在线观看视频| 亚洲熟妇久久无码精品| 日韩人妻丝袜中文字幕| 黄色在线观看免费观看在线| jul—619中文字幕在线| 在线亚洲天堂色播av电影| 久久久久久性虐视频| 亚洲综合乱码一区二区| 91九色国产熟女一区二区| 人人爽亚洲av人人爽av| 91成人精品亚洲国产| 欧美色呦呦最新网址| 黄色av网站免费在线| 久久精品国产23696| 岛国黄色大片在线观看| 91久久人澡人人添人人爽乱| 国产激情av网站在线观看| 亚洲一区二区三区uij| 青草亚洲视频在线观看| 欧美视频综合第一页| 在线视频这里只有精品自拍| 亚洲中文字幕国产日韩| 午夜久久久久久久99| 精品av国产一区二区三区四区| 亚洲码av无色中文| 1区2区3区不卡视频| 国产使劲操在线播放| 99精品视频之69精品视频| huangse网站在线观看| 国产综合高清在线观看| 黄色片年轻人在线观看| 一区二区三区四区视频| 视频一区 二区 三区 综合| 亚洲熟妇久久无码精品| 护士小嫩嫩又紧又爽20p| 四川五十路熟女av| 91中文字幕最新合集| 欧美日韩中文字幕欧美| 深夜男人福利在线观看| 黄片大全在线观看观看| 又大又湿又爽又紧A视频| 婷婷综合蜜桃av在线| 国产精品一区二区三区蜜臀av | 欧美成人精品在线观看| 在线观看免费岛国av| 只有精品亚洲视频在线观看| 国产视频网站国产视频| 欧美熟妇一区二区三区仙踪林| 国产精品成久久久久三级蜜臀av | 人妻爱爱 中文字幕| 亚洲成人av一区久久| 亚洲综合另类精品小说| 成人影片高清在线观看| 最近中文2019年在线看| 午夜福利资源综合激情午夜福利资 | 非洲黑人一级特黄片| 女生被男生插的视频网站| 伊人日日日草夜夜草| 热99re69精品8在线播放| 涩涩的视频在线观看视频| 首之国产AV医生和护士小芳| 男女第一次视频在线观看| 黑人巨大的吊bdsm| 国产亚洲成人免费在线观看| 婷婷激情四射在线观看视频| 国产成人小视频在线观看无遮挡| 色吉吉影音天天干天天操| 中文字幕之无码色多多| 51国产偷自视频在线播放| 影音先锋女人av噜噜色| 一区二区三区视频,福利一区二区| 不戴胸罩引我诱的隔壁的人妻| 精品美女福利在线观看| 五月精品丁香久久久久福利社| 国产+亚洲+欧美+另类| 色综合久久无码中文字幕波多| 亚洲欧美人精品高清| 亚洲精品在线资源站| 蜜桃视频入口久久久| 丁香花免费在线观看中文字幕| 91老师蜜桃臀大屁股| 伊人情人综合成人久久网小说| 亚洲欧美成人综合视频| 黄色av网站免费在线| 国产精品人久久久久久| 国产精品国产精品一区二区| 啊啊好大好爽啊啊操我啊啊视频| 2018在线福利视频| 国产精品自拍偷拍a| 激情五月婷婷免费视频| 国产欧美精品免费观看视频| 天天日天天摸天天爱| 日本黄在免费看视频| 无码精品一区二区三区人 | 国产性生活中老年人视频网站| 93人妻人人揉人人澡人人| 天天日天天干天天搡| 欧美日本在线视频一区| 亚洲熟女久久久36d| 黄色视频在线观看高清无码| 亚洲欧美精品综合图片小说| 最后99天全集在线观看| 在线观看视频 你懂的| 亚洲欧美激情中文字幕| 日韩人妻xxxxx| 欧美综合婷婷欧美综合| 日韩欧美中文国产在线 | 亚洲高清国产一区二区三区| 免费十精品十国产网站| 免费黄色成人午夜在线网站| 大香蕉伊人中文字幕| 欧美第一页在线免费观看视频| 欧洲欧美日韩国产在线| av在线观看网址av| 中文 成人 在线 视频| 日本美女成人在线视频| 日本午夜久久女同精女女| 中文字幕成人日韩欧美| 国产在线一区二区三区麻酥酥 | 岛国黄色大片在线观看| 日韩一区二区三区三州| 精品久久久久久久久久久a√国产| 国产变态另类在线观看| 青青青激情在线观看视频| 最新91精品视频在线| 中文字幕在线乱码一区二区| 国产使劲操在线播放| 欧美女同性恋免费a| 日韩欧美亚洲熟女人妻| 91久久综合男人天堂| 在线视频这里只有精品自拍| 偷拍自拍亚洲美腿丝袜| 9色精品视频在线观看| 成人av中文字幕一区| 老师让我插进去69AV| 亚洲图片偷拍自拍区| 日本黄在免费看视频| av完全免费在线观看av| 老熟妇凹凸淫老妇女av在线观看| 欧美亚洲免费视频观看| 欧美va亚洲va天堂va| 亚洲一区二区三区精品乱码| 亚洲天堂成人在线观看视频网站| 最新欧美一二三视频| 成人激情文学网人妻| 国产福利小视频大全| 偷青青国产精品青青在线观看| 亚洲av日韩av网站| 欧美xxx成人在线| 日韩精品中文字幕福利| 中文字幕一区二 区二三区四区| 91www一区二区三区| 欧美专区第八页一区在线播放| 亚洲日本一区二区三区| 国产精品大陆在线2019不卡| 天堂va蜜桃一区入口| 亚洲午夜高清在线观看| 天干天天天色天天日天天射| 青草青永久在线视频18| 天天操天天污天天射| av在线免费观看亚洲天堂| 91精品视频在线观看免费| 91人妻精品一区二区久久| 成人乱码一区二区三区av| 成人18禁网站在线播放| 亚洲天堂精品福利成人av| 中文字幕一区的人妻欧美日韩| 午夜青青草原网在线观看| 成熟熟女国产精品一区| 国产品国产三级国产普通话三级| 精品一区二区三区在线观看| 一区二区三区四区五区性感视频 | 日本脱亚入欧是指什么| 四川乱子伦视频国产vip| www天堂在线久久| 色综合色综合色综合色| 在线免费观看99视频| av线天堂在线观看| 第一福利视频在线观看| 夜夜操,天天操,狠狠操| 日韩北条麻妃一区在线| 狠狠地躁夜夜躁日日躁| 精品久久久久久高潮| 男人的天堂av日韩亚洲| aaa久久久久久久久| 人妻熟女在线一区二区| 熟女人妻三十路四十路人妻斩| 18禁免费av网站| 婷婷色中文亚洲网68| 日韩精品中文字幕播放| 国产 在线 免费 精品| 国产精品一区二区av国| 最新的中文字幕 亚洲| www日韩毛片av| 播放日本一区二区三区电影 | 欧美美女人体视频一区| 硬鸡巴动态操女人逼视频| 国产精品久久久久国产三级试频| 国产激情av网站在线观看| 亚洲av日韩av第一区二区三区| 天堂v男人视频在线观看| 99视频精品全部15| 少妇与子乱在线观看| 超碰在线观看免费在线观看| sspd152中文字幕在线| 黄色男人的天堂视频| 国产刺激激情美女网站| 干逼又爽又黄又免费的视频| 欧美一级视频一区二区| 韩国亚洲欧美超一级在线播放视频| 亚洲美女美妇久久字幕组| 丰满熟女午夜福利视频| 亚洲中文字幕人妻一区| 午夜福利人人妻人人澡人人爽| 最后99天全集在线观看| 99re久久这里都是精品视频| 黄色的网站在线免费看| 日本黄色三级高清视频| 亚洲精品中文字幕下载| 美女张开腿让男生操在线看| 中文字幕熟女人妻久久久| 欧美亚洲一二三区蜜臀| 国产亚洲精品欧洲在线观看| 和邻居少妇愉情中文字幕| 快插进小逼里大鸡吧视频| 大陆胖女人与丈夫操b国语高清| 在线可以看的视频你懂的| 亚洲国产美女一区二区三区软件 | 91精品国产综合久久久蜜| 亚洲av极品精品在线观看| 欧美xxx成人在线| 人妻少妇一区二区三区蜜桃| 只有精品亚洲视频在线观看| 一级a看免费观看网站| 国产性色生活片毛片春晓精品| 2020韩国午夜女主播在线| 孕妇奶水仑乱A级毛片免费看| 国产极品美女久久久久久| 亚洲av无乱一区二区三区性色| 天天做天天爽夜夜做少妇| 国产av自拍偷拍盛宴| 91中文字幕免费在线观看| 国产日韩精品电影7777| 美味人妻2在线播放| 天天操天天弄天天射| 日韩精品激情在线观看| 在线观看av亚洲情色| 国产麻豆91在线视频| 免费观看国产综合视频| 曰本无码人妻丰满熟妇啪啪| 亚洲高清视频在线不卡| 亚洲最大黄了色网站| 日本啪啪啪啪啪啪啪| 91亚洲国产成人精品性色| 青青尤物在线观看视频网站| 亚洲精品无码久久久久不卡 | 人人爽亚洲av人人爽av| 日韩成人综艺在线播放| 中文字幕,亚洲人妻| 国产乱子伦一二三区| 欧美80老妇人性视频| 在线 中文字幕 一区| 99精品一区二区三区的区| 欧美日本aⅴ免费视频| 国产精品人妻一区二区三区网站 | 亚洲精品在线资源站| 在线观看操大逼视频| 老熟妇凹凸淫老妇女av在线观看| 自拍偷拍一区二区三区图片| www久久久久久久久久久| 中文字幕人妻熟女在线电影| 日本女人一级免费片| 精品一区二区三区欧美| av新中文天堂在线网址| 午夜精品一区二区三区更新| 五十路丰满人妻熟妇| 精品国产污污免费网站入口自 | 国产综合视频在线看片| 色综合久久久久久久久中文| 国产精品三级三级三级| 一区二区三区日本伦理| 女生自摸在线观看一区二区三区| 热思思国产99re| 加勒比视频在线免费观看| 午夜国产免费福利av| 99re6热在线精品| 欧美xxx成人在线| 一区二区三区av高清免费| 狠狠躁狠狠爱网站视频 | 青青青国产片免费观看视频| 社区自拍揄拍尻屁你懂的| 精品高跟鞋丝袜一区二区| 经典国语激情内射视频| 在线视频自拍第三页| 成人国产小视频在线观看| 午夜av一区二区三区| www骚国产精品视频| 绝色少妇高潮3在线观看| 人妻少妇性色欲欧美日韩| 色综合久久五月色婷婷综合 | 精品日产卡一卡二卡国色天香| ka0ri在线视频| 啪啪啪啪啪啪啪啪啪啪黄色| 日本福利午夜电影在线观看| 91精品国产91青青碰| 午夜极品美女福利视频| 粗大的内捧猛烈进出爽大牛汉子| 欧美日韩一级黄片免费观看| 国产精品视频一区在线播放| 91一区精品在线观看| 九色精品视频在线播放| 日韩精品中文字幕播放| 可以免费看的www视频你懂的 | 日韩欧美一级aa大片| 动漫av网站18禁| 老师让我插进去69AV| 亚洲av无乱一区二区三区性色| xxx日本hd高清| 水蜜桃国产一区二区三区| 亚洲男人的天堂a在线| 色偷偷伊人大杳蕉综合网| 午夜美女少妇福利视频| 99精品国自产在线人| 国产精品国产三级国产精东| 热99re69精品8在线播放| 香蕉片在线观看av| 日本人竟这样玩学生妹| 久久久久久久亚洲午夜综合福利| av天堂加勒比在线| 青娱乐最新视频在线| 99热国产精品666| 熟女少妇激情五十路| 免费成人va在线观看| 婷婷六月天中文字幕| 91麻豆精品秘密入口在线观看| 亚洲最大免费在线观看| 成人av免费不卡在线观看| 黑人巨大精品欧美视频| 国产高清在线观看1区2区| 国产精品sm调教视频| 狠狠地躁夜夜躁日日躁| 日韩不卡中文在线视频网站| 国产av欧美精品高潮网站| 亚洲高清视频在线不卡| 中文字幕亚洲久久久| 欧美老妇精品另类不卡片| 成人sm视频在线观看| 成年女人免费播放视频| 欧美亚洲自偷自拍 在线| 国产精品黄大片在线播放| 97人人模人人爽人人喊| 亚洲欧洲一区二区在线观看| 热久久只有这里有精品| 久草视频中文字幕在线观看|