国产无遮挡裸体免费直播视频,久久精品国产蜜臀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)論

日韩欧美在线观看不卡一区二区| aaa久久久久久久久| 亚洲狠狠婷婷综合久久app| 日韩伦理短片在线观看| 中文字幕免费在线免费| 91p0rny九色露脸熟女| 青青在线视频性感少妇和隔壁黑丝 | 老司机福利精品免费视频一区二区| 自拍偷拍亚洲精品第2页| 成人蜜桃美臀九一一区二区三区| 日韩欧美一级aa大片| 色av色婷婷人妻久久久精品高清 | 亚洲va欧美va人人爽3p| 亚洲一区av中文字幕在线观看| 日韩欧美国产一区ab| yellow在线播放av啊啊啊| 91久久精品色伊人6882| 国产福利小视频大全| 高清成人av一区三区| 一级黄片久久久久久久久| 在线可以看的视频你懂的| 亚洲高清国产拍青青草原| 777奇米久久精品一区| 婷婷色中文亚洲网68| 国产卡一卡二卡三乱码手机| 亚洲 欧美 自拍 偷拍 在线| 色婷婷精品大在线观看| 国产视频在线视频播放| 久久免看30视频口爆视频| 成人av免费不卡在线观看| 一区二区三区四区中文| 99亚洲美女一区二区三区| 午夜91一区二区三区| 色狠狠av线不卡香蕉一区二区| 青青擦在线视频国产在线| 少妇系列一区二区三区视频| 精品老妇女久久9g国产| 亚洲精品亚洲人成在线导航 | 天堂av在线官网中文| 五十路老熟女码av| 成年美女黄网站18禁久久| 亚洲人妻视频在线网| 极品性荡少妇一区二区色欲| 久久丁香婷婷六月天| 天天干天天爱天天色| 欧美成人综合色在线噜噜| 免费手机黄页网址大全| 午夜频道成人在线91| 最新激情中文字幕视频| 青青草原色片网站在线观看| 蝴蝶伊人久久中文娱乐网| 亚洲一级av大片免费观看| 日本人竟这样玩学生妹| 丝袜国产专区在线观看| 久久热久久视频在线观看| 免费69视频在线看| 亚洲免费av在线视频| 亚洲精品一区二区三区老狼| 久久永久免费精品人妻专区| 日本高清撒尿pissing| 99亚洲美女一区二区三区| 午夜精品一区二区三区福利视频| 78色精品一区二区三区| 超级av免费观看一区二区三区| 国产精品自拍偷拍a| 青青青青青青青青青国产精品视频| 成人区人妻精品一区二视频| 一区二区视频在线观看免费观看| 欧美女同性恋免费a| 日本人竟这样玩学生妹| 哥哥姐姐综合激情小说| 亚洲区美熟妇久久久久| 91免费福利网91麻豆国产精品 | 激情图片日韩欧美人妻| 中文字幕无码一区二区免费| 亚洲最大免费在线观看| 亚洲少妇高潮免费观看| 亚洲中文字幕校园春色| 中文字幕亚洲久久久| 精品高跟鞋丝袜一区二区| 国内资源最丰富的网站| 美洲精品一二三产区区别| 日美女屁股黄邑视频| 男人在床上插女人视频| 天天日天天操天天摸天天舔| 亚洲成人三级在线播放 | 亚洲一区二区久久久人妻| 青青青青青免费视频| 日本www中文字幕| 欧美韩国日本国产亚洲| 亚洲卡1卡2卡三卡四老狼| 久久综合老鸭窝色综合久久| jiujiure精品视频在线| 青草亚洲视频在线观看| 爱有来生高清在线中文字幕| 国产变态另类在线观看| 国产成人精品一区在线观看| 亚洲欧美综合在线探花| chinese国产盗摄一区二区| 午夜频道成人在线91| 一区二区三区麻豆福利视频| 亚洲 清纯 国产com| 快点插进来操我逼啊视频| 天天日天天干天天搡| 夜夜骑夜夜操夜夜奸| 91色秘乱一区二区三区| 免费av岛国天堂网站| 爱爱免费在线观看视频| 国产极品美女久久久久久| 人妻丝袜精品中文字幕| 福利午夜视频在线合集| 美女操逼免费短视频下载链接| 青青青青爽手机在线| 91免费观看在线网站| 男人靠女人的逼视频| 黑人变态深video特大巨大| 91综合久久亚洲综合| 国产使劲操在线播放| eeuss鲁片一区二区三区| 亚洲一级av大片免费观看| 精品视频中文字幕在线播放| 日本免费一级黄色录像| www久久久久久久久久久| 亚洲av色图18p| 午夜91一区二区三区| 成年午夜影片国产片| 在线免费观看欧美小视频| 亚洲男人在线天堂网| 国产精品亚洲а∨天堂免| 精品久久久久久高潮| 国产精品国产精品一区二区| 日本女人一级免费片| 国产综合视频在线看片| av网址在线播放大全| 最新中文字幕乱码在线| 日韩美女精品视频在线观看网站 | 亚洲成人免费看电影| av手机免费在线观看高潮| 人妻在线精品录音叫床| 久久国产精品精品美女| 日韩成人免费电影二区| 日本少妇高清视频xxxxx | 福利视频广场一区二区| 免费无毒热热热热热热久| yy96视频在线观看| 综合精品久久久久97| 亚洲丝袜老师诱惑在线观看| 亚洲成人激情视频免费观看了 | 欧美在线一二三视频| 久久久久久99国产精品| 亚洲的电影一区二区三区| chinese国产盗摄一区二区| 1区2区3区4区视频在线观看| 在线制服丝袜中文字幕| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲av无乱一区二区三区性色| 不戴胸罩引我诱的隔壁的人妻| 亚洲精品乱码久久久本| 国产又色又刺激在线视频| 日韩欧美高清免费在线| 日本a级视频老女人| 欧亚日韩一区二区三区观看视频 | 男人插女人视频网站| 亚洲码av无色中文| 久久久精品欧洲亚洲av| 任你操视频免费在线观看| 久久99久久99精品影院| 五十路熟女av天堂| 国产自拍在线观看成人| 久久久久久久精品成人热| 极品粉嫩小泬白浆20p主播| 男人和女人激情视频| 自拍偷拍一区二区三区图片| 91精品激情五月婷婷在线| 青青青青青青草国产| 熟女俱乐部一二三区| 亚洲av色图18p| 欧美黑人性暴力猛交喷水| 亚洲av人人澡人人爽人人爱| 日韩av大胆在线观看| 久久农村老妇乱69系列| 一区二区三区欧美日韩高清播放| 99精品视频之69精品视频| 大香蕉伊人国产在线| 欧美专区日韩专区国产专区| 亚洲精品乱码久久久本| 少妇与子乱在线观看| 蜜桃视频在线欧美一区| 国产又粗又硬又大视频| 免费国产性生活视频| 91色秘乱一区二区三区| 香蕉91一区二区三区| 国产黄色片在线收看| 日本少妇人妻xxxxxhd| 欧美va不卡视频在线观看| 色哟哟在线网站入口| 福利一二三在线视频观看| 啪啪啪啪啪啪啪啪啪啪黄色| 综合精品久久久久97| 亚洲国产成人av在线一区| 国产夫妻视频在线观看免费| 免费成人va在线观看| 91精品国产高清自在线看香蕉网| 99av国产精品欲麻豆| 国产精品探花熟女在线观看| 北条麻妃肉色丝袜视频| 亚洲av日韩高清hd| 国产福利小视频免费观看| 欧美精产国品一二三产品区别大吗| 国产极品精品免费视频| 特黄老太婆aa毛毛片| 色哟哟国产精品入口| 中国黄色av一级片| av中文字幕电影在线看| 免费观看成年人视频在线观看 | 男人在床上插女人视频| 午夜的视频在线观看| 亚洲欧美清纯唯美另类 | 丝袜肉丝一区二区三区四区在线 | 老司机在线精品福利视频| 97年大学生大白天操逼| 激情人妻校园春色亚洲欧美| 插逼视频双插洞国产操逼插洞| 好吊操视频这里只有精品| 福利视频一区二区三区筱慧| 护士特殊服务久久久久久久| 亚洲熟妇无码一区二区三区| 开心 色 六月 婷婷| 亚洲欧美另类手机在线| 亚洲欧美另类自拍偷拍色图| 瑟瑟视频在线观看免费视频| 国产妇女自拍区在线观看| 日本午夜久久女同精女女| 亚洲综合另类欧美久久| 99久久久无码国产精品性出奶水| 99热久久极品热亚洲| 在线观看视频 你懂的| 欧美精品伦理三区四区| 亚洲av自拍偷拍综合| 久久热这里这里只有精品| 日本韩国免费福利精品| 91九色国产porny蝌蚪| 一区二区三区另类在线| 亚洲伊人久久精品影院一美女洗澡 | 激情国产小视频在线| 中文字幕AV在线免费看 | 在线观看黄色成年人网站| 欲满人妻中文字幕在线| 天堂av狠狠操蜜桃| 亚洲午夜高清在线观看| 在线视频免费观看网| 午夜91一区二区三区| 视频 一区二区在线观看| 在线免费观看日本片| 黄色成年网站午夜在线观看| 日本一二三中文字幕| 色偷偷伊人大杳蕉综合网| 综合页自拍视频在线播放| 91中文字幕免费在线观看| 综合页自拍视频在线播放| 538精品在线观看视频| 一区二区在线视频中文字幕| 91chinese在线视频| 18禁免费av网站| 青青草成人福利电影| av大全在线播放免费| 国产精品日韩欧美一区二区| sspd152中文字幕在线| 欧美亚洲一二三区蜜臀| 日韩人妻在线视频免费| 亚洲免费在线视频网站| 成年人黄视频在线观看| av视屏免费在线播放| 日曰摸日日碰夜夜爽歪歪| 国产麻豆剧果冻传媒app| 91精品免费久久久久久| 日日操综合成人av| 中文字幕日韩无敌亚洲精品| 亚洲一区二区三区久久午夜| 国产一区成人在线观看视频 | 亚洲中文精品字幕在线观看| 成人在线欧美日韩国产| 青青青青青青青青青青草青青| 日美女屁股黄邑视频| 男人插女人视频网站| 91成人精品亚洲国产| 国产在线免费观看成人| 性色av一区二区三区久久久| 超碰在线中文字幕一区二区| 亚洲一区二区三区av网站| 国产午夜福利av导航| 青青在线视频性感少妇和隔壁黑丝| 区一区二区三国产中文字幕| 成人18禁网站在线播放| 2021年国产精品自拍| 欧美熟妇一区二区三区仙踪林| 色综合久久五月色婷婷综合| www天堂在线久久| 国产视频一区在线观看| 日本性感美女写真视频| 日本人妻精品久久久久久| 韩国三级aaaaa高清视频| 99精品视频在线观看婷婷| 青青青青爽手机在线| 黄色片一级美女黄色片| 人妻熟女中文字幕aⅴ在线| 成人精品视频99第一页| 国产亚洲视频在线二区| 欧美成人综合色在线噜噜| 老司机免费福利视频网| 人人妻人人人操人人人爽| 亚洲伊人色一综合网| 免费岛国喷水视频在线观看 | 五月天中文字幕内射| 国产精品成久久久久三级蜜臀av | 午夜福利人人妻人人澡人人爽| 青青青青在线视频免费观看| 全国亚洲男人的天堂| 日韩中文字幕在线播放第二页| 男人的天堂在线黄色| 国产黄色a级三级三级三级| 天堂av狠狠操蜜桃| 亚洲午夜福利中文乱码字幕| 日本又色又爽又黄又粗| 国产乱子伦一二三区| 欧美日本aⅴ免费视频| 91国产在线免费播放| 粉嫩小穴流水视频在线观看| 区一区二区三国产中文字幕| 成熟丰满熟妇高潮xx×xx| 日本午夜福利免费视频| 男女之间激情网午夜在线| 大陆av手机在线观看| 综合激情网激情五月五月婷婷| 久久久久久久久久久免费女人| 亚洲一区制服丝袜美腿| 国产又大又黄免费观看| www日韩毛片av| 国产三级影院在线观看| 特黄老太婆aa毛毛片| 欧美aa一级一区三区四区 | 亚洲免费福利一区二区三区| 精品亚洲在线免费观看| 91麻豆精品传媒国产黄色片| 日本最新一二三区不卡在线| 亚洲少妇人妻无码精品| 亚洲精品欧美日韩在线播放| 韩国黄色一级二级三级| 最新91精品视频在线| 亚洲超碰97人人做人人爱| 97国产精品97久久| 在线免费视频 自拍| 中文字幕中文字幕 亚洲国产| 韩国黄色一级二级三级| 专门看国产熟妇的网站| 日本午夜福利免费视频| 日韩欧美中文国产在线 | 国产av一区2区3区| 内射久久久久综合网| 日日夜夜狠狠干视频| 天码人妻一区二区三区在线看| 欲满人妻中文字幕在线| 青草亚洲视频在线观看| 在线免费91激情四射 | 欧美精品伦理三区四区| 在线可以看的视频你懂的| 日日操夜夜撸天天干| 91在线免费观看成人| 亚洲在线免费h观看网站| 亚洲护士一区二区三区| 视频一区二区三区高清在线| 黄片色呦呦视频免费看| 久久永久免费精品人妻专区| 亚洲欧美色一区二区| 亚洲的电影一区二区三区| 午夜精品亚洲精品五月色| jiuse91九色视频| 久久h视频在线观看| 老司机深夜免费福利视频在线观看| 欧美天堂av无线av欧美| 国产精品视频欧美一区二区| 欧美激情电影免费在线| 亚洲中文字幕乱码区| 欧美少妇性一区二区三区| 亚洲男人让女人爽的视频| 欧美 亚洲 另类综合| 99视频精品全部15| 2019av在线视频| 都市激情校园春色狠狠| 免费成人va在线观看| 亚洲第一伊人天堂网| 亚洲伊人久久精品影院一美女洗澡| 特黄老太婆aa毛毛片| 最新中文字幕免费视频| 午夜婷婷在线观看视频| 日本男女操逼视频免费看| 大屁股肉感人妻中文字幕在线| 视频一区二区三区高清在线| 国产女人叫床高潮大片视频| 99久久激情婷婷综合五月天| 亚洲综合另类精品小说| 极品丝袜一区二区三区| 家庭女教师中文字幕在线播放| 精品久久久久久久久久久a√国产| 亚洲男人的天堂a在线| 熟女俱乐部一二三区| 天天日天天干天天干天天日| 久久美欧人妻少妇一区二区三区| 福利午夜视频在线观看| www日韩a级s片av| 亚洲麻豆一区二区三区| 老鸭窝在线观看一区| 国产 在线 免费 精品| 天天操天天干天天艹| 国产精品3p和黑人大战| 国产视频精品资源网站| 国产熟妇人妻ⅹxxxx麻豆| 不卡精品视频在线观看| 亚洲 中文字幕在线 日韩| 在线亚洲天堂色播av电影| 欧美精产国品一二三区| 操操网操操伊剧情片中文字幕网| 国产视频在线视频播放| 97国产福利小视频合集| 免费无毒热热热热热热久| 亚洲av无硬久久精品蜜桃| 亚洲区欧美区另类最新章节| 在线观看av亚洲情色| 少妇人妻久久久久视频黄片| 亚洲精品亚洲人成在线导航| 538精品在线观看视频| 中文字幕AV在线免费看 | 硬鸡巴动态操女人逼视频| 高清一区二区欧美系列| 人人超碰国字幕观看97| 久久这里只有精彩视频免费| weyvv5国产成人精品的视频| 人妻少妇亚洲精品中文字幕| mm131美女午夜爽爽爽| 极品粉嫩小泬白浆20p主播| 久久久超爽一二三av| 色偷偷伊人大杳蕉综合网| 久久精品国产23696| 免费观看国产综合视频| 国产在线一区二区三区麻酥酥| 国产福利小视频二区| 亚洲高清国产拍青青草原| 深田咏美亚洲一区二区| 亚洲 色图 偷拍 欧美| 中文字幕人妻熟女在线电影| 色狠狠av线不卡香蕉一区二区| 久久精品久久精品亚洲人| 免费岛国喷水视频在线观看| 久久精品国产亚洲精品166m| 中文字幕免费福利视频6| 久久久久久久精品成人热| 少妇与子乱在线观看| 天天色天天操天天透| 天天色天天舔天天射天天爽| 黄色大片免费观看网站| 国产福利小视频大全| 一区国内二区日韩三区欧美| 不卡精品视频在线观看| 激情综合治理六月婷婷| sw137 中文字幕 在线| 伊人日日日草夜夜草| 91桃色成人网络在线观看| 欧美黄色录像免费看的| 欧美怡红院视频在线观看| 久草电影免费在线观看| 精品人妻一二三区久久| 日日夜夜精品一二三| 啪啪啪啪啪啪啪啪啪啪黄色| 色av色婷婷人妻久久久精品高清| 中文字幕人妻熟女在线电影| 亚洲一区制服丝袜美腿| 欲乱人妻少妇在线视频裸| 九色porny九色9l自拍视频| 九色精品视频在线播放| 97国产福利小视频合集| 欧美乱妇无乱码一区二区| 日日夜夜大香蕉伊人| 91国内精品自线在拍白富美| 亚洲1卡2卡三卡4卡在线观看| 亚洲熟妇无码一区二区三区| 久久精品36亚洲精品束缚| 午夜精品久久久久麻豆影视| 国产一区二区在线欧美| 亚洲另类伦春色综合小| 成人免费做爰高潮视频| 亚洲av日韩精品久久久| 91在线视频在线精品3| 青青擦在线视频国产在线| 五十路老熟女码av| 福利视频广场一区二区| 男人和女人激情视频| 1024久久国产精品| 久久久超爽一二三av| 男人靠女人的逼视频| 免费黄色成人午夜在线网站| 日韩一区二区三区三州| 老司机免费视频网站在线看| 精品亚洲国产中文自在线| 天天艹天天干天天操| 一区二区三区蜜臀在线| 香蕉片在线观看av| 亚洲av天堂在线播放| 国产综合高清在线观看| 蜜臀av久久久久久久| 黄片色呦呦视频免费看| 人妻丝袜精品中文字幕| 精品成人啪啪18免费蜜臀| 年轻的人妻被夫上司侵犯| 精品久久久久久久久久久99| 天天日天天干天天插舔舔| 国产综合高清在线观看| 真实国模和老外性视频| 亚洲一区二区激情在线| 自拍偷拍 国产资源| 亚洲午夜精品小视频| 免费国产性生活视频| 国产精品国产三级国产精东 | 在线亚洲天堂色播av电影| 欧美偷拍亚洲一区二区| 精产国品久久一二三产区区别| 超碰公开大香蕉97| 欧美特色aaa大片| 亚洲 中文 自拍 无码| 亚洲激情,偷拍视频| 中文字幕亚洲久久久| 成年午夜影片国产片| 亚洲精品ww久久久久久| 特一级特级黄色网片| 自拍偷区二区三区麻豆| 日本免费午夜视频网站| 黄工厂精品视频在线观看| 91精品国产91久久自产久强| av中文字幕网址在线| 人人妻人人爱人人草| 人人妻人人爽人人澡人人精品| 久久精品美女免费视频| 成人蜜臀午夜久久一区| 日韩欧美中文国产在线| 中文字幕乱码人妻电影| 青青草人人妻人人妻| 日本一区美女福利视频| 亚洲一区av中文字幕在线观看| 免费在线看的黄网站| 日本韩国在线观看一区二区| 亚洲av可乐操首页| 男女啪啪视频免费在线观看| 国产一级精品综合av| 91大屁股国产一区二区| 中文字幕免费福利视频6| av在线播放国产不卡| 亚洲天堂成人在线观看视频网站| 国产伦精品一区二区三区竹菊| 亚洲精品ww久久久久久| 啊啊啊想要被插进去视频| 亚洲国产中文字幕啊啊啊不行了| 青草青永久在线视频18| 亚洲人妻30pwc| 日噜噜噜夜夜噜噜噜天天噜噜噜| 亚洲免费在线视频网站| 成人H精品动漫在线无码播放| 亚洲 欧美 精品 激情 偷拍| 亚洲高清自偷揄拍自拍| 97a片免费在线观看| 啊啊啊视频试看人妻| 清纯美女在线观看国产| 亚洲av成人免费网站| 最新欧美一二三视频 | 五十路熟女人妻一区二区9933| 亚洲乱码中文字幕在线| 中字幕人妻熟女人妻a62v网| 韩国男女黄色在线观看| 1区2区3区不卡视频| 2020韩国午夜女主播在线| 538精品在线观看视频| 中文字幕人妻三级在线观看| 75国产综合在线视频| 沙月文乃人妻侵犯中文字幕在线| 午夜久久久久久久99| 黄色视频成年人免费观看| 日韩二区视频一线天婷婷五| 小泽玛利亚视频在线观看| 91小伙伴中女熟女高潮| 成人动漫大肉棒插进去视频| 福利视频一区二区三区筱慧| 深田咏美亚洲一区二区| 国产美女午夜福利久久| 久久久久91精品推荐99| 亚洲av成人免费网站| 熟女在线视频一区二区三区| 中文字幕乱码av资源| 国产精品久久综合久久| 美女视频福利免费看| 日韩影片一区二区三区不卡免费| 影音先锋女人av噜噜色| 亚洲嫩模一区二区三区| 国产麻豆乱子伦午夜视频观看| 在线视频这里只有精品自拍| 91成人精品亚洲国产| 亚洲天堂精品福利成人av| 美女av色播在线播放| 欧美美女人体视频一区| 亚洲护士一区二区三区| 国产福利小视频大全| 啪啪啪啪啪啪啪啪av| 女同性ⅹxx女同h偷拍| 九九视频在线精品播放| 男人的网址你懂的亚洲欧洲av| 亚洲第一黄色在线观看| 久草视频首页在线观看| 人妻少妇性色欲欧美日韩| 日韩美av高清在线| 东游记中文字幕版哪里可以看到| 欧美国产亚洲中英文字幕| 日本在线一区二区不卡视频| 亚洲国产在人线放午夜| 98精产国品一二三产区区别| 2022中文字幕在线| 97精品人妻一区二区三区精品| 99久久激情婷婷综合五月天| 国产欧美精品不卡在线| 91国内精品久久久久精品一| 久久久久久久久久久久久97| 97超碰国语国产97超碰| 黄色大片男人操女人逼| 亚洲一级av大片免费观看| 国产女人被做到高潮免费视频 | 边摸边做超爽毛片18禁色戒| 日韩不卡中文在线视频网站| 久久永久免费精品人妻专区 | 日韩欧美亚洲熟女人妻| 无码中文字幕波多野不卡| 狠狠躁夜夜躁人人爽天天天天97| 人妻激情图片视频小说| 最新97国产在线视频| 91精品国产91久久自产久强| 久久久久久久99精品| 1区2区3区不卡视频| 亚洲av日韩av网站| 青青草精品在线视频观看| 日韩中文字幕精品淫| 成年人中文字幕在线观看| 天天日天天日天天射天天干| 在线观看一区二区三级| 国产麻豆精品人妻av| 国产免费av一区二区凹凸四季| 中国黄色av一级片| 大黑人性xxxxbbbb| 国产 在线 免费 精品| 一区二区三区综合视频| 五月婷婷在线观看视频免费 | av网站色偷偷婷婷网男人的天堂| 38av一区二区三区| 亚洲的电影一区二区三区| 好太好爽好想要免费| 午夜精品福利91av| 337p日本大胆欧美人| 中国视频一区二区三区| 亚洲 色图 偷拍 欧美| 亚洲欧美清纯唯美另类| 毛片一级完整版免费| 久久精品视频一区二区三区四区| 亚洲国产中文字幕啊啊啊不行了 | 97少妇精品在线观看| 精品亚洲国产中文自在线| 久碰精品少妇中文字幕av| 国产综合精品久久久久蜜臀| 黄色无码鸡吧操逼视频| 91九色porny蝌蚪国产成人| 国产亚洲视频在线观看| 91啪国自产中文字幕在线| 男生舔女生逼逼的视频| 欧美精产国品一二三区| 被大鸡吧操的好舒服视频免费| 97超碰国语国产97超碰| 亚洲粉嫩av一区二区三区| 中文字幕高清在线免费播放| 国产精品欧美日韩区二区| 三级av中文字幕在线观看| 偷拍自拍亚洲视频在线观看| 亚洲嫩模一区二区三区| 成人网18免费视频版国产| 日日日日日日日日夜夜夜夜夜夜| 日韩美女搞黄视频免费| 一区二区三区精品日本| 精品乱子伦一区二区三区免费播| 中文字幕亚洲久久久| 亚洲熟妇x久久av久久| 在线制服丝袜中文字幕| 一色桃子人妻一区二区三区| 精品视频中文字幕在线播放| 人人在线视频一区二区| 成年午夜免费无码区| 国产一区自拍黄视频免费观看| 国产性生活中老年人视频网站| 精品老妇女久久9g国产| 日本www中文字幕| 亚洲免费视频欧洲免费视频| 日韩美女搞黄视频免费| 99精品国自产在线人| 亚洲激情,偷拍视频| 亚洲精品一区二区三区老狼| 成人综合亚洲欧美一区 | 特一级特级黄色网片| 国产亚洲国产av网站在线| 亚洲综合在线视频可播放| 制丝袜业一区二区三区| 国产精品久久久久网| sspd152中文字幕在线| 欧美黑人性暴力猛交喷水| 国产亚洲四十路五十路| 三级黄色亚洲成人av| 色婷婷六月亚洲综合香蕉| 日本免费午夜视频网站| 东京热男人的av天堂| 区一区二区三国产中文字幕| 中文字幕日韩精品日本| 亚洲熟女久久久36d| 中文字幕一区二区人妻电影冢本| 国产成人精品av网站| 天堂va蜜桃一区入口| 特一级特级黄色网片| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 青青草国内在线视频精选| 午夜精品一区二区三区更新| 都市家庭人妻激情自拍视频| 大胆亚洲av日韩av| av中文字幕电影在线看| 免费手机黄页网址大全| 国产剧情演绎系列丝袜高跟| 香蕉av影视在线观看| 99久久超碰人妻国产| 97青青青手机在线视频| 97精品视频在线观看| 女生自摸在线观看一区二区三区 | 亚洲熟女综合色一区二区三区四区| 亚洲中文字字幕乱码| 五月婷婷在线观看视频免费| 蜜臀av久久久久蜜臀av麻豆| 青青伊人一精品视频| 78色精品一区二区三区| 天天操天天射天天操天天天| 青青青青视频在线播放| 欧美亚洲免费视频观看| 大鸡吧插逼逼视频免费看| 999九九久久久精品| 午夜精品在线视频一区| 亚洲精品av在线观看| 最新日韩av传媒在线| 国产精品一区二区av国| 国产精品成人xxxx| 男生用鸡操女生视频动漫| 国产伦精品一区二区三区竹菊| 成人av免费不卡在线观看| 四川五十路熟女av| 操的小逼流水的文章| 欧美精品免费aaaaaa| 性欧美激情久久久久久久| 日本精品一区二区三区在线视频。| 婷婷五月亚洲综合在线| 男人天堂av天天操| 国产实拍勾搭女技师av在线| 五十路熟女av天堂| 偷拍自拍国产在线视频| 香蕉91一区二区三区| 欧美日韩精品永久免费网址| 2022中文字幕在线| 精品91自产拍在线观看一区| 丰满少妇翘臀后进式| 一区二区三区视频,福利一区二区| 色综合久久无码中文字幕波多| 精品成人午夜免费看| 大鸡巴后入爆操大屁股美女| 同居了嫂子在线播高清中文| 韩国AV无码不卡在线播放| 欧美一区二区三区四区性视频| 久久亚洲天堂中文对白| 欧美va不卡视频在线观看| 75国产综合在线视频| 天天日天天日天天擦| 天天干天天爱天天色| 日韩a级黄色小视频| 欧美日本aⅴ免费视频| 国产精品一区二区久久久av| 中文字幕+中文字幕| 亚洲成人av一区久久| 欧美一区二区三区乱码在线播放| 在线观看亚洲人成免费网址| 欧美成人小视频在线免费看| 成年人的在线免费视频| 亚欧在线视频你懂的| 午夜成午夜成年片在线观看| 亚洲精品亚洲人成在线导航| 国产一线二线三线的区别在哪 | 成年人该看的视频黄免费| 99久久成人日韩欧美精品| 美味人妻2在线播放| 大香蕉伊人国产在线| 啊慢点鸡巴太大了啊舒服视频| 国产午夜男女爽爽爽爽爽视频 | 国产一区av澳门在线观看| 人妻熟女中文字幕aⅴ在线| 大香蕉福利在线观看| 偷拍美女一区二区三区| 欧美老鸡巴日小嫩逼| 国产日韩欧美视频在线导航| 亚洲va天堂va国产va久| 国产福利小视频大全| 色天天天天射天天舔| 最近中文2019年在线看| 欧美viboss性丰满| 伊人日日日草夜夜草| 在线不卡日韩视频播放| 欧美一级色视频美日韩| 阿v天堂2014 一区亚洲| 青青青青青青青青青国产精品视频| 精品91自产拍在线观看一区| 青青草人人妻人人妻| 一区二区三区日韩久久| 欧美少妇性一区二区三区| 亚洲视频在线观看高清| 免费一级特黄特色大片在线观看 | 2021天天色天天干| 天堂av在线最新版在线| 欧美黑人与人妻精品| 99精品视频之69精品视频| 一本久久精品一区二区| 91一区精品在线观看| 中国熟女@视频91| 男人的网址你懂的亚洲欧洲av| weyvv5国产成人精品的视频| 巨乳人妻日下部加奈被邻居中出 | 在线观看操大逼视频| 成人伊人精品色xxxx视频| 美女日逼视频免费观看| 激情色图一区二区三区| 国产白袜脚足J棉袜在线观看| 中文字幕 亚洲av| 亚洲av第国产精品| 人人妻人人澡欧美91精品| 真实国模和老外性视频| 99精品国自产在线人| 人人人妻人人澡人人| 在线观看视频污一区| 天堂av狠狠操蜜桃| 在线免费视频 自拍| 天天躁日日躁狠狠躁躁欧美av| 夫妻在线观看视频91| 青青青青青青青青青青草青青| 亚洲国产在人线放午夜| 成年人午夜黄片视频资源| 自拍偷拍亚洲另类色图| 又色又爽又黄的美女裸体| 动漫美女的小穴视频| 免费黄色成人午夜在线网站| 欧美偷拍自拍色图片| 中文字幕无码日韩专区免费| 天天干天天操天天玩天天射| 日本美女性生活一级片| 国产高清女主播在线| 久久麻豆亚洲精品av| 福利在线视频网址导航| 国产福利小视频免费观看| 久久精品久久精品亚洲人| 五月精品丁香久久久久福利社| 水蜜桃一区二区三区在线观看视频| 97国产精品97久久| av无限看熟女人妻另类av| 中文 成人 在线 视频| 一区二区免费高清黄色视频| 日本啪啪啪啪啪啪啪| 国产亚洲欧美视频网站| 免费在线看的黄片视频| 国产亚洲视频在线观看| 自拍偷拍日韩欧美一区二区| 白白操白白色在线免费视频| 在线观看免费av网址大全| 99国产精品窥熟女精品| 一区二区三区久久久91| 亚洲黄色av网站免费播放| 亚洲综合一区二区精品久久| 新婚人妻聚会被中出| 开心 色 六月 婷婷| 中文字幕在线第一页成人 | 精品91高清在线观看| 中文字幕国产专区欧美激情| 中文字幕乱码av资源| 欧美成人精品欧美一级黄色| 99的爱精品免费视频| 一区二区三区四区中文| 传媒在线播放国产精品一区| 91成人精品亚洲国产| 91精品视频在线观看免费| 男人的天堂av日韩亚洲| 色av色婷婷人妻久久久精品高清| 久久久噜噜噜久久熟女av| 国产综合视频在线看片| 自拍偷拍日韩欧美一区二区| 亚洲成人av一区在线| 亚洲一区二区三区精品视频在线 | 中国视频一区二区三区| 久久精品国产999| 成人蜜桃美臀九一一区二区三区| 欧美亚洲中文字幕一区二区三区 | 美洲精品一二三产区区别| 北条麻妃av在线免费观看| 精品成人啪啪18免费蜜臀| av新中文天堂在线网址| 国产黄色片在线收看| 欧洲日韩亚洲一区二区三区| 大胆亚洲av日韩av| 日本成人不卡一区二区| 一个人免费在线观看ww视频| 国产一区二区神马久久| 班长撕开乳罩揉我胸好爽| 中文字幕人妻被公上司喝醉在线| 一区二区三区精品日本| 3337p日本欧洲大胆色噜噜| 人人妻人人澡人人爽人人dvl| 国产精品免费不卡av| 国产美女精品福利在线| 国产综合视频在线看片| 国产精品女邻居小骚货| 中文字幕熟女人妻久久久| 一个人免费在线观看ww视频| 少妇高潮无套内谢麻豆| 一区二区在线视频中文字幕| 日日夜夜狠狠干视频| 中文人妻AV久久人妻水| sw137 中文字幕 在线| 一区二区三区av高清免费| 国产中文精品在线观看| 丝袜肉丝一区二区三区四区在线 | 精品一区二区三区午夜| 国产日韩一区二区在线看 | 水蜜桃国产一区二区三区| 在线制服丝袜中文字幕| 国产成人小视频在线观看无遮挡| 人妻凌辱欧美丰满熟妇| 大鸡吧插逼逼视频免费看| 国产三级片久久久久久久| 欧美日韩高清午夜蜜桃大香蕉| 亚洲成人精品女人久久久| 自拍偷拍一区二区三区图片| 日韩中文字幕精品淫| 在线免费观看日本伦理| 极品性荡少妇一区二区色欲| 天天插天天狠天天操| 亚洲视频在线观看高清| 夫妻在线观看视频91| 日本少妇人妻xxxxx18| 大香蕉大香蕉大香蕉大香蕉大香蕉| 超级福利视频在线观看| 伊人综合免费在线视频| 亚洲 人妻 激情 中文| 精品91高清在线观看 | 92福利视频午夜1000看| 40道精品招牌菜特色| 国产福利小视频大全| 人妻丰满熟妇综合网| 亚洲成人国产综合一区| v888av在线观看视频| 天天做天天干天天舔| yy6080国产在线视频| 欲满人妻中文字幕在线| 国产黄网站在线观看播放| jiuse91九色视频| 夜夜操,天天操,狠狠操| 婷婷综合蜜桃av在线| 在线免费观看视频一二区| 亚洲少妇高潮免费观看| 亚洲欧洲一区二区在线观看| 香蕉aⅴ一区二区三区| 国产精品国产精品一区二区| 国语对白xxxx乱大交| 涩涩的视频在线观看视频| 成人蜜臀午夜久久一区| mm131美女午夜爽爽爽| 91国语爽死我了不卡| 福利在线视频网址导航| 人妻无码中文字幕专区| 91香蕉成人app下载| 亚洲人妻av毛片在线| 日韩欧美在线观看不卡一区二区| 亚洲成a人片777777| 38av一区二区三区| 青青青青在线视频免费观看| 国产乱弄免费视频观看| 久久热这里这里只有精品| 一区二区熟女人妻视频| 国产视频在线视频播放| 成人24小时免费视频| 国产黄色片蝌蚪九色91| 一区二区三区精品日本| 日本熟女精品一区二区三区| 综合精品久久久久97| 桃色视频在线观看一区二区| 国产三级片久久久久久久 | 青青草视频手机免费在线观看| 大胆亚洲av日韩av| 91国内视频在线观看| 黑人借宿ntr人妻的沦陷2| 一区二区三区精品日本| 国产熟妇人妻ⅹxxxx麻豆| 黄页网视频在线免费观看 | 国产精品国产三级麻豆| 国产精品黄片免费在线观看| 免费观看国产综合视频| 欧美精产国品一二三区| 免费十精品十国产网站| 红杏久久av人妻一区| 蜜桃色婷婷久久久福利在线| 亚洲一区二区三区精品视频在线 | 精品国产乱码一区二区三区乱| 2025年人妻中文字幕乱码在线| 欧美成人精品在线观看| aaa久久久久久久久| 日韩美女综合中文字幕pp| 天天日天天爽天天干| 中国熟女@视频91| 岛国黄色大片在线观看| 中文字母永久播放1区2区3区| 天天日天天干天天要| 一区二区三区四区五区性感视频| 中文字幕在线欧美精品| 91精品高清一区二区三区| 国内资源最丰富的网站| 好太好爽好想要免费| 日本一二三中文字幕| 青青青青青青草国产| 国产综合视频在线看片| 看一级特黄a大片日本片黑人| 亚洲推理片免费看网站| 欧美亚洲中文字幕一区二区三区| 亚洲精品 欧美日韩| 亚洲嫩模一区二区三区| 青青草视频手机免费在线观看| 视频一区二区综合精品| 97人人妻人人澡人人爽人人精品| 97色视频在线观看| 第一福利视频在线观看| 久久丁香花五月天色婷婷| 中文字幕乱码人妻电影| 国产日本精品久久久久久久| 91av精品视频在线| 91麻豆精品传媒国产黄色片| 国产伦精品一区二区三区竹菊| 亚洲一区二区三区精品乱码| 中文字幕乱码av资源| 国产美女精品福利在线| 2020久久躁狠狠躁夜夜躁| 亚洲国产免费av一区二区三区| 40道精品招牌菜特色| 精品美女在线观看视频在线观看| 久草视频首页在线观看| 77久久久久国产精产品| 白白操白白色在线免费视频| 色综合久久五月色婷婷综合| 深田咏美亚洲一区二区| 国产欧美精品一区二区高清| 2018在线福利视频| 国产真实灌醉下药美女av福利| 啪啪啪18禁一区二区三区 | 久久精品国产999| 中文字幕一区二区三区人妻大片| 国产日韩一区二区在线看| 日本成人一区二区不卡免费在线 | 国产精品亚洲在线观看| 免费观看丰满少妇做受| 99一区二区在线观看| 99精品国产aⅴ在线观看| 国产卡一卡二卡三乱码手机| 2020韩国午夜女主播在线| 国产之丝袜脚在线一区二区三区 | 精品国产高潮中文字幕| 一区二区久久成人网| 人妻少妇av在线观看| 精产国品久久一二三产区区别| 精品人妻伦一二三区久| 亚洲av自拍偷拍综合| 天天操天天干天天艹| 日本一道二三区视频久久| 福利一二三在线视频观看| 99久久中文字幕一本人| 日韩在线视频观看有码在线| 91色网站免费在线观看| 9国产精品久久久久老师 | 一区二区三区四区视频| 一区二区三区的久久的蜜桃的视频| 特一级特级黄色网片| 男人的网址你懂的亚洲欧洲av| 把腿张开让我插进去视频| 午夜成午夜成年片在线观看| 人妻久久久精品69系列| 成人久久精品一区二区三区| 国产高清精品极品美女| 亚洲av第国产精品| 欧美偷拍自拍色图片| 欧美成人小视频在线免费看| 国产福利小视频二区| 亚洲 图片 欧美 图片| 熟妇一区二区三区高清版| 国产成人精品久久二区91| 少妇与子乱在线观看| 五月天久久激情视频| 国产精品国产三级国产午| 欧美一区二区三区高清不卡tv | 黄色片黄色片wyaa| 一区二区三区激情在线| 久久一区二区三区人妻欧美| 中文字幕在线视频一区二区三区| 国产一区二区欧美三区| 狠狠的往里顶撞h百合| 100%美女蜜桃视频| 又色又爽又黄又刺激av网站| 97人人妻人人澡人人爽人人精品| 亚洲中文字幕人妻一区| 少妇深喉口爆吞精韩国| 青青青aaaa免费| 绝顶痉挛大潮喷高潮无码| 国产精品中文av在线播放| 把腿张开让我插进去视频| 日本啪啪啪啪啪啪啪| 在线观看欧美黄片一区二区三区| 亚洲av极品精品在线观看| 亚洲国产欧美国产综合在线| 乱亲女秽乱长久久久| 精品一区二区三四区| 青青青国产免费视频| 成人av中文字幕一区| 欧美精品欧美极品欧美视频 | 偷偷玩弄新婚人妻h视频| 亚洲人妻30pwc| 啪啪啪啪啪啪啪啪av| 国产九色91在线观看精品| 天堂女人av一区二区| 狠狠的往里顶撞h百合| 免费69视频在线看| 全国亚洲男人的天堂| 蜜桃精品久久久一区二区| 天天日天天干天天爱| 加勒比视频在线免费观看| 欲满人妻中文字幕在线| 欧洲亚洲欧美日韩综合| 国产精品久久久黄网站| 啪啪啪18禁一区二区三区| 最新日韩av传媒在线| 成人免费毛片aaaa| 激情内射在线免费观看| 最新欧美一二三视频| 年轻的人妻被夫上司侵犯| 国产精品视频男人的天堂| 亚洲区美熟妇久久久久| 国产乱子伦一二三区| 午夜美女福利小视频| 国产熟妇一区二区三区av| 国产一区二区神马久久| 亚洲av男人天堂久久| 青娱乐极品视频青青草| 99精品国产免费久久| 粉嫩av蜜乳av蜜臀| 中文乱理伦片在线观看| 午夜场射精嗯嗯啊啊视频| 888欧美视频在线| 久久久久久久一区二区三| 熟女少妇激情五十路| 日本韩国免费福利精品| 中文字幕—97超碰网| 免费观看成年人视频在线观看| 欧美久久一区二区伊人| 动漫美女的小穴视频| av手机在线免费观看日韩av| 国产一区二区火爆视频| 涩涩的视频在线观看视频| 欧美日韩情色在线观看| 日韩成人免费电影二区| 青青在线视频性感少妇和隔壁黑丝| 色综合久久无码中文字幕波多| 亚洲欧美久久久久久久久| 亚洲综合自拍视频一区| 91天堂精品一区二区| 日本熟妇喷水xxx| 深田咏美亚洲一区二区| 九色视频在线观看免费| 天天日天天干天天舔天天射| 亚洲高清国产自产av| 天堂va蜜桃一区入口| 99精品一区二区三区的区| 国产chinesehd精品麻豆| 久久www免费人成一看片| 亚洲av自拍天堂网| 亚洲一区二区三区精品乱码| 一区二区免费高清黄色视频| 成人av中文字幕一区| 美女张开腿让男生操在线看| 在线观看欧美黄片一区二区三区| 国产视频网站一区二区三区 | 99久久成人日韩欧美精品| 欧美日韩精品永久免费网址| 人妻丰满熟妇综合网| 91啪国自产中文字幕在线| 亚洲中文字幕国产日韩| 爱爱免费在线观看视频| 任你操视频免费在线观看| 色婷婷精品大在线观看| 亚洲无线观看国产高清在线| 激情内射在线免费观看| 亚洲伊人av天堂有码在线| 狍和女人的王色毛片| 在线播放国产黄色av| 久草视频中文字幕在线观看| 亚洲1卡2卡三卡4卡在线观看| 天天操天天弄天天射| 在线观看免费视频网| 全国亚洲男人的天堂| 日本av熟女在线视频| 大香蕉大香蕉大香蕉大香蕉大香蕉| 毛茸茸的大外阴中国视频| 午夜免费体验区在线观看| 久久久久久9999久久久久| 在线观看成人国产电影| 亚洲2021av天堂| 国产不卡av在线免费| av天堂资源最新版在线看| 日韩美女福利视频网| 国产1区,2区,3区| 欧美另类z0z变态| 成人在线欧美日韩国产| av破解版在线观看| 爱爱免费在线观看视频| 中文字幕在线欧美精品| 欧美3p在线观看一区二区三区| 日本少妇精品免费视频| 91国产在线视频免费观看| 成人H精品动漫在线无码播放| 一区二区三区四区中文| 日本丰满熟妇大屁股久久| 福利视频广场一区二区| 欧美亚洲中文字幕一区二区三区 | 激情五月婷婷综合色啪| 精品老妇女久久9g国产| 国产av自拍偷拍盛宴| 三上悠亚和黑人665番号| 夜女神免费福利视频| 最后99天全集在线观看| 久草视频 久草视频2| avjpm亚洲伊人久久| 狠狠操操操操操操操操操 | 久草电影免费在线观看| 亚洲最大黄 嗯色 操 啊| 欧美成人综合视频一区二区| 亚洲高清免费在线观看视频| 久草福利电影在线观看| 免费在线看的黄网站| mm131美女午夜爽爽爽| 国产片免费观看在线观看| 自拍 日韩 欧美激情| 国产亚州色婷婷久久99精品| 欧美偷拍自拍色图片| 特黄老太婆aa毛毛片| 亚洲av琪琪男人的天堂| 红杏久久av人妻一区| 动漫美女的小穴视频| 人妻熟女在线一区二区| 欧美一区二区中文字幕电影| 一区二区在线视频中文字幕| 久草免费人妻视频在线| 成人在线欧美日韩国产| 97超碰免费在线视频| 激情人妻校园春色亚洲欧美| 男女啪啪视频免费在线观看| 大鸡巴插入美女黑黑的阴毛| 2021年国产精品自拍| 天天干天天日天天谢综合156| 中国黄色av一级片| 大鸡巴操娇小玲珑的女孩逼| 97小视频人妻一区二区| 新婚人妻聚会被中出| 激情啪啪啪啪一区二区三区| 天天操天天干天天插| 少妇一区二区三区久久久| 老司机免费福利视频网| 成人高潮aa毛片免费| 青青青青爽手机在线| 国产精品人妻66p| 天天操天天干天天日狠狠插 | 亚洲伊人久久精品影院一美女洗澡 | 偷拍3456eee| 黄色大片免费观看网站| 亚洲美女美妇久久字幕组| 国产熟妇人妻ⅹxxxx麻豆| 91人妻精品久久久久久久网站| 丝袜美腿视频诱惑亚洲无| 国产精品伦理片一区二区| 欧美va不卡视频在线观看| 天天干天天插天天谢| 99精品视频在线观看免费播放| 19一区二区三区在线播放| 亚洲 清纯 国产com| 国产成人自拍视频在线免费观看| 日韩二区视频一线天婷婷五| 99热久久这里只有精品8| 精品国产在线手机在线| 国产中文精品在线观看| 看一级特黄a大片日本片黑人| 蜜桃专区一区二区在线观看| 特黄老太婆aa毛毛片| 直接能看的国产av| yellow在线播放av啊啊啊| 亚洲欧美综合在线探花| 大白屁股精品视频国产| 一色桃子人妻一区二区三区| 人人妻人人爽人人澡人人精品| 欧美日本国产自视大全| 国产精品欧美日韩区二区| 福利午夜视频在线观看| 老司机福利精品免费视频一区二区| 亚洲一区二区三区精品乱码| av一本二本在线观看| 啊啊好慢点插舔我逼啊啊啊视频| 最近的中文字幕在线mv视频| 一区二区三区毛片国产一区| 日韩激情文学在线视频| 青青青视频自偷自拍38碰| 国产真实乱子伦a视频| 99热99这里精品6国产| 韩国AV无码不卡在线播放| 喷水视频在线观看这里只有精品| 黄色成人在线中文字幕| 黄色大片免费观看网站| 91精品国产观看免费| gay gay男男瑟瑟在线网站| 社区自拍揄拍尻屁你懂的| 亚洲一区二区久久久人妻| 日本欧美视频在线观看三区| 成人综合亚洲欧美一区| 韩国黄色一级二级三级| 色秀欧美视频第一页| 成人网18免费视频版国产| 亚洲精品国产综合久久久久久久久| 成人性黑人一级av| 成年人该看的视频黄免费| 黄色片黄色片wyaa| 国产视频一区在线观看| 天天操夜夜操天天操天天操| 经典国语激情内射视频| 美女被肏内射视频网站| 国产日韩一区二区在线看| 亚洲午夜电影在线观看| 欧美亚洲国产成人免费在线| 一二三区在线观看视频| 清纯美女在线观看国产| 午夜福利资源综合激情午夜福利资| 在线新三级黄伊人网| 又色又爽又黄的美女裸体| 中文字幕亚洲中文字幕| 天天干狠狠干天天操| 51国产成人精品视频| 中字幕人妻熟女人妻a62v网| 中文字幕一区二区三区蜜月| 亚欧在线视频你懂的| 在线免费观看av日韩| 91极品大一女神正在播放| 一色桃子久久精品亚洲| 天天射,天天操,天天说| 青青青青青操视频在线观看| 久久机热/这里只有| 亚洲成人熟妇一区二区三区| 国产夫妻视频在线观看免费| 久草视频在线看免费| 天天干天天操天天爽天天摸 | 国产又粗又黄又硬又爽| 欧美中国日韩久久精品| 美女日逼视频免费观看| 午夜精品一区二区三区城中村| 色综合色综合色综合色| 日本韩国在线观看一区二区| 98视频精品在线观看| 人人超碰国字幕观看97| 蜜臀av久久久久蜜臀av麻豆| 国产大学生援交正在播放| 亚洲一区二区三区uij| 又粗又硬又猛又爽又黄的| 可以免费看的www视频你懂的| 亚洲天堂精品福利成人av| 欧美黑人巨大性xxxxx猛交| 日日夜夜狠狠干视频| 97年大学生大白天操逼| 国产真实灌醉下药美女av福利| 91九色国产熟女一区二区| 亚洲一区二区三区久久午夜| 班长撕开乳罩揉我胸好爽| 久久免费看少妇高潮完整版| 国产内射中出在线观看| 精品一区二区三区欧美| 91大神福利视频网| 亚洲免费视频欧洲免费视频| xxx日本hd高清| 国产超码片内射在线| 91精品高清一区二区三区| 超碰97免费人妻麻豆| 欧美女同性恋免费a| 操操网操操伊剧情片中文字幕网| 天天操夜夜操天天操天天操| 97国产福利小视频合集| 97人妻总资源视频| 国产熟妇一区二区三区av| 国产一区二区欧美三区| 中文字幕在线乱码一区二区| 97人人妻人人澡人人爽人人精品| 久久久精品国产亚洲AV一| 2025年人妻中文字幕乱码在线| 在线免费观看日本伦理| 黑人大几巴狂插日本少妇| 538精品在线观看视频| 国产成人精品福利短视频| 午夜毛片不卡在线看| 社区自拍揄拍尻屁你懂的| 成年人免费看在线视频| 免费黄页网站4188| 日本免费午夜视频网站| 亚洲综合一区成人在线| 性感美女福利视频网站| 日本少妇在线视频大香蕉在线观看 | 内射久久久久综合网| 国产一区av澳门在线观看| 成年人黄色片免费网站| 热久久只有这里有精品| 日韩人妻丝袜中文字幕| 久久农村老妇乱69系列| 国产又粗又硬又猛的毛片视频| 中文字幕在线乱码一区二区| 日韩欧美国产一区不卡| 精品高跟鞋丝袜一区二区| 大屁股肉感人妻中文字幕在线| 91在线视频在线精品3| 国产精品一二三不卡带免费视频 | 在线观看欧美黄片一区二区三区| 日韩精品中文字幕播放| 2021国产一区二区| 大学生A级毛片免费视频| 国产av欧美精品高潮网站| 精品一区二区三区三区色爱| 91精品国产高清自在线看香蕉网| 91精品国产91久久自产久强| 中文字幕免费在线免费| 日本啪啪啪啪啪啪啪| 精品区一区二区三区四区人妻| 天天射夜夜操狠狠干| 91九色国产porny蝌蚪| 啊啊啊想要被插进去视频| 亚洲乱码中文字幕在线| 最新91九色国产在线观看| 毛片一级完整版免费| 国产91久久精品一区二区字幕| 搡老熟女一区二区在线观看| xxx日本hd高清| 天天操天天插天天色| 黄色资源视频网站日韩| 操日韩美女视频在线免费看| 91超碰青青中文字幕| 激情国产小视频在线| 二区中出在线观看老师 | 美女少妇亚洲精选av| 国产伦精品一区二区三区竹菊| 中字幕人妻熟女人妻a62v网| 精品国产污污免费网站入口自| 2022中文字幕在线| 91麻豆精品传媒国产黄色片| 国产精品国色综合久久| 18禁网站一区二区三区四区| 激情综合治理六月婷婷| 天天操夜夜操天天操天天操| 真实国产乱子伦一区二区| 欧美viboss性丰满| 又色又爽又黄又刺激av网站| av在线播放国产不卡| 欧美日韩亚洲国产无线码| 又色又爽又黄的美女裸体| 啊啊好慢点插舔我逼啊啊啊视频| 欧美亚洲偷拍自拍色图| 日韩精品中文字幕播放| 极品粉嫩小泬白浆20p主播| 久草视频在线免播放| 成熟丰满熟妇高潮xx×xx| 日韩近亲视频在线观看| 久久久精品精品视频视频| 综合精品久久久久97| 亚洲av日韩高清hd| 成人精品在线观看视频| 免费在线看的黄片视频| 青青青青青手机视频| 丰满少妇翘臀后进式| 美女福利视频导航网站| 晚上一个人看操B片| 激情小视频国产在线| 亚洲欧美自拍另类图片| 天天日天天天天天天天天天天| 九九视频在线精品播放| a v欧美一区=区三区| 成人18禁网站在线播放| 专门看国产熟妇的网站| 1000小视频在线| 亚洲激情唯美亚洲激情图片| 亚洲一级 片内射视正片| 99国内精品永久免费视频| 日韩近亲视频在线观看| 超碰97人人做人人爱| 91久久国产成人免费网站| 在线播放 日韩 av| 亚洲午夜精品小视频| 亚洲国产香蕉视频在线播放| 不戴胸罩引我诱的隔壁的人妻| 一区二区在线视频中文字幕 | 国产精品亚洲在线观看| 黄色成人在线中文字幕| 亚洲 清纯 国产com| 亚洲一区二区三区av网站| 精品成人啪啪18免费蜜臀| 热思思国产99re| 插小穴高清无码中文字幕| 天天日天天干天天爱| 精产国品久久一二三产区区别| 久久精品视频一区二区三区四区 | a v欧美一区=区三区| 激情啪啪啪啪一区二区三区| 小泽玛利亚视频在线观看| 91成人精品亚洲国产| 在线免费91激情四射| 国产va在线观看精品| 人妻久久久精品69系列| 老司机午夜精品视频资源| 国产91精品拍在线观看| 成人性黑人一级av| 亚洲综合一区成人在线| 久精品人妻一区二区三区 | 少妇被强干到高潮视频在线观看| 中文字幕高清资源站| 国产视频在线视频播放| 午夜精彩视频免费一区| 国产综合高清在线观看| 成人24小时免费视频| 国产亚洲天堂天天一区| 国产成人小视频在线观看无遮挡| 狠狠的往里顶撞h百合| 天天日天天干天天爱| 夜夜嗨av蜜臀av| 欧美视频一区免费在线| 成年人啪啪视频在线观看| 欧美亚洲免费视频观看| 人人妻人人爱人人草| 日本一道二三区视频久久| 97超碰人人搞人人| 午夜频道成人在线91| 2018最新中文字幕在线观看| 色呦呦视频在线观看视频| 在线观看免费岛国av| 亚洲av黄色在线网站| 黄色黄色黄片78在线| 欧美3p在线观看一区二区三区| 欧美精品中文字幕久久二区| 天天日夜夜干天天操| 日辽宁老肥女在线观看视频| 99视频精品全部15| 亚洲午夜伦理视频在线| 97小视频人妻一区二区| 国产精品久久9999| 亚洲一区二区三区精品视频在线 | 成人av亚洲一区二区| 丝袜长腿第一页在线| 国产精品国产三级国产精东| 女人精品内射国产99| 日本阿v视频在线免费观看| 国产剧情演绎系列丝袜高跟| 免费十精品十国产网站| 最新国产亚洲精品中文在线| 国产成人精品福利短视频| 91试看福利一分钟| 欧美成人猛片aaaaaaa| 亚洲1区2区3区精华液| 人妻丰满熟妇综合网| 婷婷久久久综合中文字幕| 大白屁股精品视频国产| 欧美老妇精品另类不卡片| 国产 在线 免费 精品| 天天操天天插天天色| 免费69视频在线看| 精品老妇女久久9g国产| 亚洲中文字幕综合小综合| 亚洲精品无码色午夜福利理论片| 国产自拍在线观看成人| 91试看福利一分钟| 中文字幕日韩无敌亚洲精品 | 国产一区二区三免费视频| 老熟妇凹凸淫老妇女av在线观看| 综合页自拍视频在线播放| 国产女人被做到高潮免费视频 | 无码日韩人妻精品久久| 黄色的网站在线免费看| yy6080国产在线视频| 在线播放国产黄色av| 国产成人精品久久二区91| 亚洲一区制服丝袜美腿| 老司机免费福利视频网| 久久久人妻一区二区| 免费成人va在线观看| 中文字幕免费福利视频6| 日本性感美女三级视频| 精品欧美一区二区vr在线观看| 天天插天天狠天天操| 51国产偷自视频在线播放| 亚洲国产成人在线一区| 经典国语激情内射视频| 国产精品一区二区三区蜜臀av| 夏目彩春在线中文字幕| 欧美韩国日本国产亚洲| 国产成人小视频在线观看无遮挡| 抽查舔水白紧大视频| 中文字幕av男人天堂| 2020久久躁狠狠躁夜夜躁| 亚洲少妇人妻无码精品| 这里有精品成人国产99| 视频 国产 精品 熟女 | 国产精品欧美日韩区二区| 偷青青国产精品青青在线观看 | 亚洲伊人av天堂有码在线| 中文字幕在线观看国产片| 青草青永久在线视频18| 老司机福利精品视频在线| 亚洲欧美日韩视频免费观看| 真实国产乱子伦一区二区| 天天日天天天天天天天天天天 | 欧美性感尤物人妻在线免费看| 中文字幕日韩91人妻在线| 精品一区二区三区在线观看| 中文字幕—97超碰网| 日本韩国免费一区二区三区视频| 亚洲天堂第一页中文字幕| 极品粉嫩小泬白浆20p主播| 午夜精品久久久久久99热| 黑人巨大的吊bdsm| 国产女人被做到高潮免费视频| 精品91自产拍在线观看一区| 国产伊人免费在线播放| 99热国产精品666| 色婷婷综合激情五月免费观看 | 国产中文字幕四区在线观看| 亚洲日本一区二区久久久精品| 五月天色婷婷在线观看视频免费| 自拍偷拍亚洲欧美在线视频| 男人天堂最新地址av| 国产品国产三级国产普通话三级| 日韩a级黄色小视频| 国产欧美精品一区二区高清 | 日韩欧美在线观看不卡一区二区| 亚洲图库另类图片区| 亚洲成人av一区在线| 中文字幕乱码人妻电影| av无限看熟女人妻另类av| 日本av高清免费网站| 福利片区一区二体验区| 日韩不卡中文在线视频网站| 黄色中文字幕在线播放| 亚洲av午夜免费观看| 午夜免费观看精品视频| 欧美日韩情色在线观看| 久久久久五月天丁香社区| 阿v天堂2014 一区亚洲| 97资源人妻免费在线视频| 孕妇奶水仑乱A级毛片免费看| 中文字幕在线乱码一区二区| 天天日天天鲁天天操| 欧美黑人性猛交xxxxⅹooo| 日日摸夜夜添夜夜添毛片性色av| 国产av自拍偷拍盛宴| 蜜桃臀av蜜桃臀av| 精品首页在线观看视频| 日韩激情文学在线视频| 国产精品入口麻豆啊啊啊| 色爱av一区二区三区| 午夜激情高清在线观看| 午夜精品福利91av| 人妻最新视频在线免费观看| 在线免费观看99视频| 婷婷综合蜜桃av在线| 国产va在线观看精品| 中文字幕一区二区三区人妻大片| 青青青青操在线观看免费| 超鹏97历史在线观看| 国产精品日韩欧美一区二区| 日本av熟女在线视频| 国产欧美精品不卡在线| 精品人妻每日一部精品| 夜夜骑夜夜操夜夜奸| 国产精品国产三级国产精东| 日韩成人免费电影二区| 午夜dv内射一区区| 一区二区三区 自拍偷拍| 五十路老熟女码av| 国产精品人妻熟女毛片av久| 黄色片黄色片wyaa| 国产又粗又硬又猛的毛片视频| 熟女国产一区亚洲中文字幕| 国产综合高清在线观看| 人妻少妇亚洲精品中文字幕| 亚洲1卡2卡三卡4卡在线观看| 韩国一级特黄大片做受| 国产成人精品一区在线观看| 国产一区二区火爆视频| 粉嫩av蜜乳av蜜臀| 日本又色又爽又黄又粗| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 亚洲欧美色一区二区| 视频二区在线视频观看| 日韩影片一区二区三区不卡免费| 三级黄色亚洲成人av| 免费成人va在线观看| 国产av自拍偷拍盛宴| 国产精品3p和黑人大战| 91啪国自产中文字幕在线| 新婚人妻聚会被中出| 黄色大片男人操女人逼| 久久久久久99国产精品| 最新国产精品拍在线观看| 色狠狠av线不卡香蕉一区二区| 伊人情人综合成人久久网小说| 水蜜桃国产一区二区三区| 视频 一区二区在线观看| 亚洲av日韩av第一区二区三区| 动漫av网站18禁| 亚洲国产精品久久久久蜜桃| 国产精品人妻一区二区三区网站 | 在线免费观看欧美小视频| 国产日韩一区二区在线看| 在线观看视频 你懂的| 2017亚洲男人天堂| 天天干天天操天天爽天天摸| 国产大鸡巴大鸡巴操小骚逼小骚逼| 久久99久久99精品影院| 在线观看免费av网址大全| 97成人免费在线观看网站| 日本美女成人在线视频| 青春草视频在线免费播放| 免费av岛国天堂网站| 天堂资源网av中文字幕| 国产视频一区二区午夜| 最新欧美一二三视频| 日韩加勒比东京热二区| 久精品人妻一区二区三区| 国产高清精品极品美女| 老司机欧美视频在线看| 特一级特级黄色网片| 97人妻夜夜爽二区欧美极品| 超碰97人人做人人爱| av在线免费中文字幕| 日本一二三区不卡无| 午夜青青草原网在线观看| 99热99re在线播放| 91高清成人在线视频| 福利午夜视频在线观看| 中英文字幕av一区| 99精品一区二区三区的区| 日噜噜噜夜夜噜噜噜天天噜噜噜| 亚洲欧美精品综合图片小说| heyzo蜜桃熟女人妻| 久久久噜噜噜久久熟女av| 国产精品亚洲在线观看| 欧美成人猛片aaaaaaa| av在线免费中文字幕| 在线不卡日韩视频播放| 成人网18免费视频版国产| 亚洲av色图18p| 午夜91一区二区三区| 中文字幕免费福利视频6| 免费看国产又粗又猛又爽又黄视频 | 亚洲一区二区三区精品视频在线| 美女张开腿让男生操在线看| 日本熟妇丰满厨房55| 日本精品一区二区三区在线视频。| 天天插天天色天天日| 国产亚洲欧美45p| 日本熟妇色熟妇在线观看| 92福利视频午夜1000看| 国产性生活中老年人视频网站| 一二三区在线观看视频| 91九色porny国产在线| 久精品人妻一区二区三区| 国产麻豆剧果冻传媒app| 日韩成人性色生活片| 亚洲国产成人最新资源| 亚洲国产最大av综合| 天天干天天操天天摸天天射| 国产在线拍揄自揄视频网站| 成人午夜电影在线观看 久久| 日韩影片一区二区三区不卡免费| 欧美综合婷婷欧美综合| 久久久久只精品国产三级| 亚洲欧美成人综合视频| 制服丝袜在线人妻中文字幕| 国产真实乱子伦a视频| 六月婷婷激情一区二区三区| 视频一区 视频二区 视频| 亚洲一区二区久久久人妻| 精品亚洲在线免费观看| avjpm亚洲伊人久久| 亚洲精品国产综合久久久久久久久| 久久午夜夜伦痒痒想咳嗽P| 和邻居少妇愉情中文字幕| 中文字幕第1页av一天堂网| 国产女人叫床高潮大片视频| 国产性生活中老年人视频网站| 一级A一级a爰片免费免会员| 天天日天天干天天舔天天射| 国产精品视频资源在线播放| 国产精品一区二区久久久av| 午夜精品福利91av| 中文字幕亚洲久久久| 91人妻人人做人人爽在线| 午夜福利人人妻人人澡人人爽 | 91精品国产91青青碰| 少妇人妻真实精品视频| 熟女人妻一区二区精品视频| 免费观看理论片完整版| 人妻熟女中文字幕aⅴ在线| 国产夫妻视频在线观看免费 | 2022精品久久久久久中文字幕| 在线观看黄色成年人网站| 日日夜夜大香蕉伊人| av视网站在线观看| 亚洲一级av大片免费观看| 国产精彩福利精品视频| 亚洲一区二区三区精品乱码| 亚洲免费va在线播放| 国产一区二区欧美三区| 天堂资源网av中文字幕| 888欧美视频在线| 男女第一次视频在线观看| 色哟哟在线网站入口| 午夜激情高清在线观看| 午夜极品美女福利视频| 只有精品亚洲视频在线观看| 亚洲第17页国产精品| 人妻无码色噜噜狠狠狠狠色| 小泽玛利亚视频在线观看| 欧美伊人久久大香线蕉综合| 在线观看黄色成年人网站| 天天干天天插天天谢| 国产精品久久久久久久久福交| 天天干天天操天天扣| 日本a级视频老女人| 啪啪啪啪啪啪啪啪啪啪黄色| 777奇米久久精品一区| 激情小视频国产在线| 国产变态另类在线观看| 制服丝袜在线人妻中文字幕| 91欧美在线免费观看| 在线不卡日韩视频播放| 国产欧美日韩第三页| av完全免费在线观看av| 国产男女视频在线播放| japanese五十路熟女熟妇| 亚洲中文字幕乱码区| 天天干天天插天天谢| 国产91久久精品一区二区字幕| 久久久精品国产亚洲AV一| 91精品免费久久久久久| 亚洲精品欧美日韩在线播放 | 亚洲中文字幕人妻一区| 最新国产精品拍在线观看| 五十路息与子猛烈交尾视频| 婷婷色国产黑丝少妇勾搭AV| 久碰精品少妇中文字幕av| jiujiure精品视频在线| 久久丁香婷婷六月天| 国产黄色大片在线免费播放 | 免费手机黄页网址大全| 人人超碰国字幕观看97| 亚洲区欧美区另类最新章节| 国产污污污污网站在线| 国产精品黄色的av| 亚洲另类在线免费观看| 精品一区二区三区在线观看| 超碰97免费人妻麻豆| 日韩一区二区三区三州| 干逼又爽又黄又免费的视频| 熟女视频一区,二区,三区| 亚洲av琪琪男人的天堂| 国产成人精品久久二区91| 久久久精品999精品日本| 日韩av熟妇在线观看| 日韩美女福利视频网| 97资源人妻免费在线视频| 国产91精品拍在线观看| 日韩中文字幕在线播放第二页| 亚洲精品无码色午夜福利理论片| 日本三极片中文字幕| 2021天天色天天干| 午夜成午夜成年片在线观看| 自拍偷拍一区二区三区图片| 亚洲综合自拍视频一区| 亚洲 欧美 自拍 偷拍 在线| 涩涩的视频在线观看视频| 国产精品污污污久久| www天堂在线久久| 亚洲激情唯美亚洲激情图片| 内射久久久久综合网| 中文字幕一区二区人妻电影冢本| 丝袜肉丝一区二区三区四区在线 | 亚洲高清一区二区三区视频在线| 韩国三级aaaaa高清视频| 欧美视频不卡一区四区| 日韩精品二区一区久久| 一区二区免费高清黄色视频| 青青在线视频性感少妇和隔壁黑丝| 伊人综合aⅴ在线网| 色97视频在线播放| 天天日夜夜操天天摸| 黄色在线观看免费观看在线| 又黄又刺激的午夜小视频| 精品国产成人亚洲午夜| 精产国品久久一二三产区区别| 黄色视频成年人免费观看| 顶级尤物粉嫩小尤物网站| 93人妻人人揉人人澡人人| 久久午夜夜伦痒痒想咳嗽P| 青青青视频手机在线观看| 久久久精品999精品日本| www久久久久久久久久久| 天天躁夜夜躁日日躁a麻豆| av视网站在线观看| 日本脱亚入欧是指什么| 欧美aa一级一区三区四区| 久久精品在线观看一区二区| 欧美亚洲偷拍自拍色图| 亚洲av日韩高清hd| 天天日天天干天天干天天日| 青青草成人福利电影| 又色又爽又黄又刺激av网站| 北条麻妃av在线免费观看| 91精品啪在线免费| 亚洲卡1卡2卡三卡四老狼| 国产精品久久久久国产三级试频| 久久美欧人妻少妇一区二区三区| 日本熟妇丰满厨房55| 午夜美女福利小视频| 三级等保密码要求条款| 午夜大尺度无码福利视频| 欧美aa一级一区三区四区 | 日本少妇的秘密免费视频| 国产精品人妻一区二区三区网站| 日本性感美女视频网站| av日韩在线免费播放| 欧美精品黑人性xxxx| 国产av国片精品一区二区| 日本美女成人在线视频| 91精品国产黑色丝袜| 免费69视频在线看| 久久这里只有精品热视频 | 女蜜桃臀紧身瑜伽裤| 99精品一区二区三区的区| 久久亚洲天堂中文对白| 亚洲av可乐操首页| 91中文字幕最新合集| 日本啪啪啪啪啪啪啪| 久久香蕉国产免费天天| 日本性感美女三级视频| 人妻爱爱 中文字幕| 亚洲av男人的天堂你懂的| 插逼视频双插洞国产操逼插洞| av男人天堂狠狠干| 19一区二区三区在线播放| 欧美日韩人妻久久精品高清国产| 欧美地区一二三专区| 天天草天天色天天干| 亚洲精品一线二线在线观看| 亚洲另类伦春色综合小| 男人的网址你懂的亚洲欧洲av| 色偷偷伊人大杳蕉综合网| 三级av中文字幕在线观看| 丝袜肉丝一区二区三区四区在线| 少妇一区二区三区久久久| 在线播放一区二区三区Av无码| 久久精品国产999| 国产精彩对白一区二区三区| 五月天色婷婷在线观看视频免费| 欧美成人综合视频一区二区 | 日韩一个色综合导航| 97精品人妻一区二区三区精品| 亚洲欧美另类自拍偷拍色图| 久久久久久久久久久久久97| 精品av久久久久久久| 日日摸夜夜添夜夜添毛片性色av| 东游记中文字幕版哪里可以看到| 亚洲av人人澡人人爽人人爱| av资源中文字幕在线观看| 亚洲专区激情在线观看视频| 日韩亚国产欧美三级涩爱| 久草电影免费在线观看| 2020久久躁狠狠躁夜夜躁 | 国产亚洲精品欧洲在线观看| 成人综合亚洲欧美一区| 成人资源在线观看免费官网| 久久这里只有精彩视频免费| 人妻在线精品录音叫床| 欧美精品激情在线最新观看视频| 2012中文字幕在线高清| 国产精品三级三级三级| 人妻3p真实偷拍一二区| 9l人妻人人爽人人爽| 亚洲国产免费av一区二区三区 | 亚洲 图片 欧美 图片| 亚洲精品精品国产综合| 欧美日韩高清午夜蜜桃大香蕉| 天天日夜夜干天天操| 日本a级视频老女人| 日本av在线一区二区三区| 不卡一不卡二不卡三| 欧美精产国品一二三产品价格| 日韩国产乱码中文字幕| 午夜精品九一唐人麻豆嫩草成人| 青青青青青青草国产| 色婷婷精品大在线观看| 人妻凌辱欧美丰满熟妇| 成年人黄视频在线观看| 亚洲成av人无码不卡影片一| 黄色片年轻人在线观看| 亚洲特黄aaaa片| 黄色录像鸡巴插进去| 在线观看欧美黄片一区二区三区| 久久久人妻一区二区| 97瑟瑟超碰在线香蕉| 亚洲欧美福利在线观看| 黄片色呦呦视频免费看| 日曰摸日日碰夜夜爽歪歪| 日韩激情文学在线视频| 福利午夜视频在线合集| 成人av电影免费版| 丝袜美腿视频诱惑亚洲无| 国产三级影院在线观看| 国产精品入口麻豆啊啊啊 | 丰满少妇人妻xxxxx| 欧美久久一区二区伊人| 韩国三级aaaaa高清视频| 精品久久久久久高潮| 日本男女操逼视频免费看| 色综合天天综合网国产成人| 少妇人妻100系列| 在线免费观看日本片| jul—619中文字幕在线| 国产精品久久久久国产三级试频| 人妻久久无码中文成人| 日韩a级精品一区二区| 人妻少妇性色欲欧美日韩| 国产精品久久久久久久精品视频| 欧美成人综合色在线噜噜| 污污小视频91在线观看| 国产极品美女久久久久久| 亚洲高清一区二区三区视频在线| 水蜜桃一区二区三区在线观看视频 | 国产精品国色综合久久| 午夜精品一区二区三区更新| 亚洲精品成人网久久久久久小说| 漂亮 人妻被中出中文| 99热久久极品热亚洲| 久久尻中国美女视频| 日韩中文字幕精品淫| 青春草视频在线免费播放| 中文字幕日韩人妻在线三区| 在线不卡成人黄色精品| 经典av尤物一区二区| 在线观看国产网站资源| 精品久久久久久高潮| 天天躁夜夜躁日日躁a麻豆| 91p0rny九色露脸熟女| 国产在线自在拍91国语自产精品| 日比视频老公慢点好舒服啊| 少妇人妻真实精品视频| 国产美女精品福利在线| 93精品视频在线观看| 天天操天天射天天操天天天 | 国产九色91在线观看精品| 日本最新一二三区不卡在线 | 含骚鸡巴玩逼逼视频| ka0ri在线视频| 欧美黑人性暴力猛交喷水| 婷婷色中文亚洲网68| 欧美精品中文字幕久久二区| 自拍偷区二区三区麻豆| 国产1区,2区,3区| 国产精品自拍偷拍a| 伊人开心婷婷国产av| 亚洲精品乱码久久久本| 超污视频在线观看污污污| 久久美欧人妻少妇一区二区三区| 98视频精品在线观看| 91高清成人在线视频| 亚洲av日韩高清hd| 久久艹在线观看视频| 黑人解禁人妻叶爱071| 91桃色成人网络在线观看| AV天堂一区二区免费试看| 亚洲国产精品免费在线观看| 婷婷久久一区二区字幕网址你懂得| 在线观看视频污一区| 亚洲成a人片777777| 青青擦在线视频国产在线| 麻豆精品成人免费视频| 伊人情人综合成人久久网小说| 久久三久久三久久三久久| 热久久只有这里有精品| 一区二区三区毛片国产一区| 日本在线不卡免费视频| av森泽佳奈在线观看| 偷拍自拍亚洲美腿丝袜| 中国熟女@视频91| 中英文字幕av一区| 国产一区二区神马久久| 男人插女人视频网站| 中文字幕无码一区二区免费| 国产janese在线播放| 99国内小视频在现欢看| 丝袜美腿视频诱惑亚洲无| 欧美久久久久久三级网| 成人性黑人一级av| 国产精品sm调教视频| 午夜免费体验区在线观看| 一个人免费在线观看ww视频| 19一区二区三区在线播放| 在线亚洲天堂色播av电影| 插小穴高清无码中文字幕| 综合精品久久久久97| 超鹏97历史在线观看| 国产日韩精品免费在线| 久久精品国产999| av中文字幕在线观看第三页| 精彩视频99免费在线| 中文字幕一区二区人妻电影冢本| 夜夜嗨av蜜臀av| 97瑟瑟超碰在线香蕉| 国产麻豆剧果冻传媒app| 日韩美av高清在线| 熟女人妻在线中出观看完整版| 婷婷五月亚洲综合在线| 亚洲成高清a人片在线观看| 人人妻人人澡欧美91精品| 青青青青操在线观看免费| 91天堂天天日天天操| 在线观看视频一区麻豆| 中文字幕在线一区精品| 91综合久久亚洲综合| 成年午夜免费无码区| 亚洲中文精品字幕在线观看| 高潮喷水在线视频观看| 99精品免费久久久久久久久a| 国产视频在线视频播放| 日韩欧美一级精品在线观看| 国产97在线视频观看| 丝袜美腿视频诱惑亚洲无| 亚洲蜜臀av一区二区三区九色| huangse网站在线观看| 亚洲欧美综合在线探花| 97人人妻人人澡人人爽人人精品| 中文字幕亚洲中文字幕| 天天日天天爽天天干| 丰满的继坶3中文在线观看| 亚洲国产香蕉视频在线播放| 清纯美女在线观看国产| 中文字幕av一区在线观看| 九一传媒制片厂视频在线免费观看| 五十路在线观看完整版| 成人蜜桃美臀九一一区二区三区| 国产视频网站国产视频| 福利午夜视频在线观看| 福利视频网久久91| 免费手机黄页网址大全| 亚洲无码一区在线影院| 视频 国产 精品 熟女 | 久久h视频在线观看| 五十路在线观看完整版| 国产精品自拍偷拍a| 偷青青国产精品青青在线观看 | 日本成人一区二区不卡免费在线| 国产精品中文av在线播放| 大白屁股精品视频国产| 午夜在线精品偷拍一区二| 亚洲国产精品美女在线观看| 日本高清撒尿pissing| jul—619中文字幕在线| 婷婷激情四射在线观看视频| 欧美成人综合色在线噜噜| 亚洲精品在线资源站| 亚洲熟女综合色一区二区三区四区| 精品黑人一区二区三区久久国产 | 成年人黄视频在线观看| 91桃色成人网络在线观看| 国产精品入口麻豆啊啊啊| 亚洲高清视频在线不卡| 天天操天天爽天天干| 日本www中文字幕| 精品一区二区三区三区88| av亚洲中文天堂字幕网| 婷婷色中文亚洲网68| 不戴胸罩引我诱的隔壁的人妻| 国产精品一区二区三区蜜臀av| 2012中文字幕在线高清| 97瑟瑟超碰在线香蕉| 成人24小时免费视频| 伊人成人综合开心网| 精品一区二区三四区| 国产精品大陆在线2019不卡| 九色视频在线观看免费| 宅男噜噜噜666免费观看| 蜜桃视频在线欧美一区| 18禁网站一区二区三区四区| 风流唐伯虎电视剧在线观看| 成熟熟女国产精品一区| 91综合久久亚洲综合| 人妻自拍视频中国大陆| 国产激情av网站在线观看| 黑人3p华裔熟女普通话| av高潮迭起在线观看| 亚洲丝袜老师诱惑在线观看| 99精品国自产在线人| 人妻熟女中文字幕aⅴ在线| 国产变态另类在线观看| 亚洲av午夜免费观看| 欧美偷拍自拍色图片| 狍和女人的王色毛片| 一级黄片大鸡巴插入美女| 一区国内二区日韩三区欧美| 欧美精产国品一二三产品区别大吗| 在线观看国产免费麻豆| 91在线视频在线精品3| 日美女屁股黄邑视频| 国产精品自拍在线视频| 18禁无翼鸟成人在线| 久久久人妻一区二区| 精品国产午夜视频一区二区| 国产福利小视频二区| 人妻另类专区欧美制服| 日本高清在线不卡一区二区| 黄网十四区丁香社区激情五月天| 9l人妻人人爽人人爽| 97精品综合久久在线| 免费十精品十国产网站| 97黄网站在线观看| 天天日天天干天天要| 黄色男人的天堂视频| 亚洲va国产va欧美精品88| 中文字幕日韩精品就在这里| 哥哥姐姐综合激情小说| 国产成人无码精品久久久电影| 99热99re在线播放| 不卡日韩av在线观看| 91色秘乱一区二区三区| 早川濑里奈av黑人番号| 五十路熟女人妻一区二| 一本一本久久a久久精品综合不卡 亚洲另类综合一区小说 | 人妻激情图片视频小说| 很黄很污很色的午夜网站在线观看 | 久久亚洲天堂中文对白| 视频啪啪啪免费观看| 韩国一级特黄大片做受| 性欧美日本大妈母与子| 国产chinesehd精品麻豆| 涩爱综合久久五月蜜臀| 日本三极片中文字幕| 亚洲成人免费看电影| 18禁免费av网站| 99久久99久国产黄毛片| 成人伊人精品色xxxx视频| 久久这里只有精品热视频 | 绝顶痉挛大潮喷高潮无码 | 综合色区亚洲熟妇shxstz| 美日韩在线视频免费看| 中文字幕—97超碰网| 任你操任你干精品在线视频| 中国视频一区二区三区| 北条麻妃高跟丝袜啪啪| 欧美交性又色又爽又黄麻豆| 日本人妻欲求不满中文字幕| 欧美专区第八页一区在线播放 | 天天日天天干天天舔天天射| 国内自拍第一页在线观看| 亚洲一区二区三区久久午夜| 夜夜嗨av一区二区三区中文字幕| 国产视频精品资源网站| 在线网站你懂得老司机| 插小穴高清无码中文字幕| 女警官打开双腿沦为性奴| 亚洲麻豆一区二区三区| 黄色片黄色片wyaa| 91免费福利网91麻豆国产精品| 黄色视频成年人免费观看| 最新激情中文字幕视频| 日日操综合成人av| 偷拍自拍福利视频在线观看| 日本精品美女在线观看| 精品美女在线观看视频在线观看| 啪啪啪18禁一区二区三区| 大尺度激情四射网站| 中文字幕成人日韩欧美| gogo国模私拍视频| 日本啪啪啪啪啪啪啪| av高潮迭起在线观看| 亚洲超碰97人人做人人爱| 精品亚洲国产中文自在线| 日韩剧情片电影在线收看| 日本精品视频不卡一二三| 青青青青青青青青青国产精品视频| 在线免费观看黄页视频| nagger可以指黑人吗| 97成人免费在线观看网站| 亚洲精品成人网久久久久久小说| 国产成人一区二区三区电影网站| 懂色av之国产精品| 日本免费一级黄色录像| 亚洲一级 片内射视正片| 五月激情婷婷久久综合网| 成人高潮aa毛片免费| 中文字幕视频一区二区在线观看| 福利午夜视频在线观看| 亚洲国产第一页在线观看| 4个黑人操素人视频网站精品91| AV无码一区二区三区不卡| 涩涩的视频在线观看视频| 日韩欧美高清免费在线| 黄色大片男人操女人逼| 丰满的子国产在线观看| 全国亚洲男人的天堂| 国产黄色大片在线免费播放 | 激情五月婷婷综合色啪| 激情图片日韩欧美人妻| 91片黄在线观看喷潮| 夜夜操,天天操,狠狠操| 玩弄人妻熟妇性色av少妇| 国产视频一区在线观看| 99的爱精品免费视频| 国产97视频在线精品| 国产一区二区火爆视频| 欧美日韩激情啪啪啪| 黑人解禁人妻叶爱071| chinese国产盗摄一区二区| 在线观看日韩激情视频| 成人网18免费视频版国产| 夜夜骑夜夜操夜夜奸| 亚洲av日韩av第一区二区三区| 爱有来生高清在线中文字幕| 欧美日本在线观看一区二区| 天天干天天操天天扣| 99热色原网这里只有精品| 自拍 日韩 欧美激情| 亚洲美女美妇久久字幕组| 久久丁香花五月天色婷婷| 成人激情文学网人妻| 麻豆性色视频在线观看| 在线观看欧美黄片一区二区三区| 加勒比视频在线免费观看| 大白屁股精品视频国产| 国产视频一区二区午夜| 亚洲图片偷拍自拍区| 欧美成人一二三在线网| 免费在线观看视频啪啪| 在线观看免费视频色97| 日韩精品中文字幕播放| 午夜激情高清在线观看| 91精品国产91青青碰| 久久人人做人人妻人人玩精品vr| 欧美专区日韩专区国产专区| 农村胖女人操逼视频| 亚洲成人三级在线播放| 在线观看亚洲人成免费网址| 午夜毛片不卡在线看| 日本福利午夜电影在线观看| 91九色porny国产蝌蚪视频| 日本www中文字幕| 91精品一区二区三区站长推荐| 日本人妻欲求不满中文字幕| 少妇露脸深喉口爆吞精| 岛国一区二区三区视频在线| 国产黄色片蝌蚪九色91| 日韩a级黄色小视频| 青青青国产免费视频| 日韩av有码一区二区三区4 | 一级黄片久久久久久久久| 绝色少妇高潮3在线观看| 蜜桃视频在线欧美一区| 国产精品午夜国产小视频| 99亚洲美女一区二区三区| 日韩一个色综合导航| 欧美久久久久久三级网| 日本乱人一区二区三区| 瑟瑟视频在线观看免费视频| 在线网站你懂得老司机| 亚洲天堂精品久久久| 人妻凌辱欧美丰满熟妇| 亚洲综合乱码一区二区| 久久综合老鸭窝色综合久久| 青青擦在线视频国产在线| 少妇被强干到高潮视频在线观看| 日视频免费在线观看| 欧美中国日韩久久精品| 久草极品美女视频在线观看| 最新国产亚洲精品中文在线| 日韩成人免费电影二区| 51国产偷自视频在线播放| 我想看操逼黄色大片| 丰满少妇人妻xxxxx| 91she九色精品国产| 亚洲欧美激情国产综合久久久| 绝色少妇高潮3在线观看| 黄色成年网站午夜在线观看| 91精品资源免费观看| 高潮视频在线快速观看国家快速| 中文字幕 码 在线视频| 五月激情婷婷久久综合网| 亚洲中文字幕人妻一区| av天堂中文免费在线| 成年人免费看在线视频| 青青青青青青青青青国产精品视频| 精品一区二区三区在线观看| 欧美在线偷拍视频免费看| 午夜婷婷在线观看视频| 男人的网址你懂的亚洲欧洲av| 日本脱亚入欧是指什么|