亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

SQL語句執(zhí)行深入講解(MySQL架構(gòu)總覽->查詢執(zhí)行流程->SQL解析順序)

2024-07-25 19:09:32
字體:
供稿:網(wǎng)友

前言:

一直是想知道一條SQL語句是怎么被執(zhí)行的,它執(zhí)行的順序是怎樣的,然后查看總結(jié)各方資料,就有了下面這一篇博文了。

本文將從MySQL總體架構(gòu)--->查詢執(zhí)行流程--->語句執(zhí)行順序來探討一下其中的知識。

一、MySQL架構(gòu)總覽:

架構(gòu)最好看圖,再配上必要的說明文字。

下圖根據(jù)參考書籍中一圖為原本,再在其上添加上了自己的理解。

 SQL語句,執(zhí)行,順序

從上圖中我們可以看到,整個架構(gòu)分為兩層,上層是MySQLD的被稱為的‘SQL Layer',下層是各種各樣對上提供接口的存儲引擎,被稱為‘Storage Engine Layer'。其它各個模塊和組件,從名字上就可以簡單了解到它們的作用,這里就不再累述了。

二、查詢執(zhí)行流程

下面再向前走一些,容我根據(jù)自己的認(rèn)識說一下查詢執(zhí)行的流程是怎樣的:

1.連接

  1.1客戶端發(fā)起一條Query請求,監(jiān)聽客戶端的‘連接管理模塊'接收請求

  1.2將請求轉(zhuǎn)發(fā)到‘連接進/線程模塊'

  1.3調(diào)用‘用戶模塊'來進行授權(quán)檢查

  1.4通過檢查后,‘連接進/線程模塊'從‘線程連接池'中取出空閑的被緩存的連接線程和客戶端請求對接,如果失敗則創(chuàng)建一個新的連接請求

2.處理

  2.1先查詢緩存,檢查Query語句是否完全匹配,接著再檢查是否具有權(quán)限,都成功則直接取數(shù)據(jù)返回

  2.2上一步有失敗則轉(zhuǎn)交給‘命令解析器',經(jīng)過詞法分析,語法分析后生成解析樹

  2.3接下來是預(yù)處理階段,處理解析器無法解決的語義,檢查權(quán)限等,生成新的解析樹

  2.4再轉(zhuǎn)交給對應(yīng)的模塊處理

  2.5如果是SELECT查詢還會經(jīng)由‘查詢優(yōu)化器'做大量的優(yōu)化,生成執(zhí)行計劃

  2.6模塊收到請求后,通過‘訪問控制模塊'檢查所連接的用戶是否有訪問目標(biāo)表和目標(biāo)字段的權(quán)限

  2.7有則調(diào)用‘表管理模塊',先是查看table cache中是否存在,有則直接對應(yīng)的表和獲取鎖,否則重新打開表文件

  2.8根據(jù)表的meta數(shù)據(jù),獲取表的存儲引擎類型等信息,通過接口調(diào)用對應(yīng)的存儲引擎處理

  2.9上述過程中產(chǎn)生數(shù)據(jù)變化的時候,若打開日志功能,則會記錄到相應(yīng)二進制日志文件中

3.結(jié)果

  3.1Query請求完成后,將結(jié)果集返回給‘連接進/線程模塊'

  3.2返回的也可以是相應(yīng)的狀態(tài)標(biāo)識,如成功或失敗等

  3.3‘連接進/線程模塊'進行后續(xù)的清理工作,并繼續(xù)等待請求或斷開與客戶端的連接

一圖小總結(jié)

SQL語句,執(zhí)行,順序

三、SQL解析順序

接下來再走一步,讓我們看看一條SQL語句的前世今生。

首先看一下示例語句

SELECT DISTINCT < select_list >FROM < left_table > < join_type >JOIN < right_table > ON < join_condition >WHERE < where_condition >GROUP BY < group_by_list >HAVING < having_condition >ORDER BY < order_by_condition >LIMIT < limit_number >

然而它的執(zhí)行順序是這樣的

FROM <left_table>ON <join_condition><join_type> JOIN <right_table>WHERE <where_condition>GROUP BY <group_by_list>HAVING <having_condition>SELECT DISTINCT <select_list>ORDER BY <order_by_condition>LIMIT <limit_number>

雖然自己沒想到是這樣的,不過一看還是很自然和諧的,從哪里獲取,不斷的過濾條件,要選擇一樣或不一樣的,排好序,那才知道要取前幾條呢。

既然如此了,那就讓我們一步步來看看其中的細節(jié)吧。

準(zhǔn)備工作

1.創(chuàng)建測試數(shù)據(jù)庫

create database testQuery

2.創(chuàng)建測試表

CREATE TABLE table1( uid VARCHAR(10) NOT NULL, name VARCHAR(10) NOT NULL, PRIMARY KEY(uid))ENGINE=INNODB DEFAULT CHARSET=UTF8;CREATE TABLE table2( oid INT NOT NULL auto_increment, uid VARCHAR(10), PRIMARY KEY(oid))ENGINE=INNODB DEFAULT CHARSET=UTF8;

3.插入數(shù)據(jù)

INSERT INTO table1(uid,name) VALUES('aaa','mike'),('bbb','jack'),('ccc','mike'),('ddd','mike');INSERT INTO table2(uid) VALUES('aaa'),('aaa'),('bbb'),('bbb'),('bbb'),('ccc'),(NULL);

4.最后想要的結(jié)果

SELECT a.uid, count(b.oid) AS totalFROM table1 AS aLEFT JOIN table2 AS b ON a.uid = b.uidWHERE a. NAME = 'mike'GROUP BY a.uidHAVING count(b.oid) < 2ORDER BY total DESCLIMIT 1;

!現(xiàn)在開始SQL解析之旅吧!

1. FROM

當(dāng)涉及多個表的時候,左邊表的輸出會作為右邊表的輸入,之后會生成一個虛擬表VT1。

(1-J1)笛卡爾積

計算兩個相關(guān)聯(lián)表的笛卡爾積(CROSS JOIN) ,生成虛擬表VT1-J1。

mysql> select * from table1,table2;+-----+------+-----+------+| uid | name | oid | uid |+-----+------+-----+------+| aaa | mike | 1 | aaa || bbb | jack | 1 | aaa || ccc | mike | 1 | aaa || ddd | mike | 1 | aaa || aaa | mike | 2 | aaa || bbb | jack | 2 | aaa || ccc | mike | 2 | aaa || ddd | mike | 2 | aaa || aaa | mike | 3 | bbb || bbb | jack | 3 | bbb || ccc | mike | 3 | bbb || ddd | mike | 3 | bbb || aaa | mike | 4 | bbb || bbb | jack | 4 | bbb || ccc | mike | 4 | bbb || ddd | mike | 4 | bbb || aaa | mike | 5 | bbb || bbb | jack | 5 | bbb || ccc | mike | 5 | bbb || ddd | mike | 5 | bbb || aaa | mike | 6 | ccc || bbb | jack | 6 | ccc || ccc | mike | 6 | ccc || ddd | mike | 6 | ccc || aaa | mike | 7 | NULL || bbb | jack | 7 | NULL || ccc | mike | 7 | NULL || ddd | mike | 7 | NULL |+-----+------+-----+------+rows in set (0.00 sec)

(1-J2)ON過濾

基于虛擬表VT1-J1這一個虛擬表進行過濾,過濾出所有滿足ON 謂詞條件的列,生成虛擬表VT1-J2。

注意:這里因為語法限制,使用了'WHERE'代替,從中讀者也可以感受到兩者之間微妙的關(guān)系;

mysql> SELECT -> * -> FROM -> table1, -> table2 -> WHERE -> table1.uid = table2.uid -> ;+-----+------+-----+------+| uid | name | oid | uid |+-----+------+-----+------+| aaa | mike | 1 | aaa || aaa | mike | 2 | aaa || bbb | jack | 3 | bbb || bbb | jack | 4 | bbb || bbb | jack | 5 | bbb || ccc | mike | 6 | ccc |+-----+------+-----+------+rows in set (0.00 sec)

(1-J3)添加外部列

如果使用了外連接(LEFT,RIGHT,FULL),主表(保留表)中的不符合ON條件的列也會被加入到VT1-J2中,作為外部行,生成虛擬表VT1-J3。

mysql> SELECT -> * -> FROM -> table1 AS a -> LEFT OUTER JOIN table2 AS b ON a.uid = b.uid;+-----+------+------+------+| uid | name | oid | uid |+-----+------+------+------+| aaa | mike | 1 | aaa || aaa | mike | 2 | aaa || bbb | jack | 3 | bbb || bbb | jack | 4 | bbb || bbb | jack | 5 | bbb || ccc | mike | 6 | ccc || ddd | mike | NULL | NULL |+-----+------+------+------+rows in set (0.00 sec)

下面從網(wǎng)上找到一張很形象的關(guān)于‘SQL JOINS'的解釋圖,如若侵犯了你的權(quán)益,請勞煩告知刪除,謝謝。

SQL語句,執(zhí)行,順序

2. WHERE

對VT1過程中生成的臨時表進行過濾,滿足WHERE子句的列被插入到VT2表中。

注意:

此時因為分組,不能使用聚合運算;也不能使用SELECT中創(chuàng)建的別名;

與ON的區(qū)別:

如果有外部列,ON針對過濾的是關(guān)聯(lián)表,主表(保留表)會返回所有的列;

如果沒有添加外部列,兩者的效果是一樣的;

應(yīng)用:

對主表的過濾應(yīng)該放在WHERE;

對于關(guān)聯(lián)表,先條件查詢后連接則用ON,先連接后條件查詢則用WHERE;

mysql> SELECT -> * -> FROM -> table1 AS a -> LEFT OUTER JOIN table2 AS b ON a.uid = b.uid -> WHERE -> a. NAME = 'mike';+-----+------+------+------+| uid | name | oid | uid |+-----+------+------+------+| aaa | mike | 1 | aaa || aaa | mike | 2 | aaa || ccc | mike | 6 | ccc || ddd | mike | NULL | NULL |+-----+------+------+------+rows in set (0.00 sec)

3. GROUP BY

這個子句會把VT2中生成的表按照GROUP BY中的列進行分組。生成VT3表。

注意:

其后處理過程的語句,如SELECT,HAVING,所用到的列必須包含在GROUP BY中,對于沒有出現(xiàn)的,得用聚合函數(shù);

原因:

GROUP BY改變了對表的引用,將其轉(zhuǎn)換為新的引用方式,能夠?qū)ζ溥M行下一級邏輯操作的列會減少;

我的理解是:

根據(jù)分組字段,將具有相同分組字段的記錄歸并成一條記錄,因為每一個分組只能返回一條記錄,除非是被過濾掉了,而不在分組字段里面的字段可能會有多個值,多個值是無法放進一條記錄的,所以必須通過聚合函數(shù)將這些具有多值的列轉(zhuǎn)換成單值;

mysql> SELECT -> * -> FROM -> table1 AS a -> LEFT OUTER JOIN table2 AS b ON a.uid = b.uid -> WHERE -> a. NAME = 'mike' -> GROUP BY -> a.uid;+-----+------+------+------+| uid | name | oid | uid |+-----+------+------+------+| aaa | mike | 1 | aaa || ccc | mike | 6 | ccc || ddd | mike | NULL | NULL |+-----+------+------+------+rows in set (0.00 sec)

4. HAVING

這個子句對VT3表中的不同的組進行過濾,只作用于分組后的數(shù)據(jù),滿足HAVING條件的子句被加入到VT4表中。

mysql> SELECT -> * -> FROM -> table1 AS a -> LEFT OUTER JOIN table2 AS b ON a.uid = b.uid -> WHERE -> a. NAME = 'mike' -> GROUP BY -> a.uid -> HAVING -> count(b.oid) < 2;+-----+------+------+------+| uid | name | oid | uid |+-----+------+------+------+| ccc | mike | 6 | ccc || ddd | mike | NULL | NULL |+-----+------+------+------+rows in set (0.00 sec)

5. SELECT

這個子句對SELECT子句中的元素進行處理,生成VT5表。

(5-J1)計算表達式 計算SELECT 子句中的表達式,生成VT5-J1

(5-J2)DISTINCT

尋找VT5-1中的重復(fù)列,并刪掉,生成VT5-J2

如果在查詢中指定了DISTINCT子句,則會創(chuàng)建一張內(nèi)存臨時表(如果內(nèi)存放不下,就需要存放在硬盤了)。這張臨時表的表結(jié)構(gòu)和上一步產(chǎn)生的虛擬表VT5是一樣的,不同的是對進行DISTINCT操作的列增加了一個唯一索引,以此來除重復(fù)數(shù)據(jù)。

mysql> SELECT -> a.uid, -> count(b.oid) AS total -> FROM -> table1 AS a -> LEFT OUTER JOIN table2 AS b ON a.uid = b.uid -> WHERE -> a. NAME = 'mike' -> GROUP BY -> a.uid -> HAVING -> count(b.oid) < 2;+-----+-------+| uid | total |+-----+-------+| ccc |  1 || ddd |  0 |+-----+-------+rows in set (0.00 sec)

6.ORDER BY

從VT5-J2中的表中,根據(jù)ORDER BY 子句的條件對結(jié)果進行排序,生成VT6表。

注意:

唯一可使用SELECT中別名的地方;

mysql> SELECT -> a.uid, -> count(b.oid) AS total -> FROM -> table1 AS a -> LEFT OUTER JOIN table2 AS b ON a.uid = b.uid -> WHERE -> a. NAME = 'mike' -> GROUP BY -> a.uid -> HAVING -> count(b.oid) < 2 -> ORDER BY -> total DESC;+-----+-------+| uid | total |+-----+-------+| ccc |  1 || ddd |  0 |+-----+-------+rows in set (0.00 sec)

7.LIMIT

LIMIT子句從上一步得到的VT6虛擬表中選出從指定位置開始的指定行數(shù)據(jù)。

注意:

offset和rows的正負(fù)帶來的影響;

當(dāng)偏移量很大時效率是很低的,可以這么做:

采用子查詢的方式優(yōu)化,在子查詢里先從索引獲取到最大id,然后倒序排,再取N行結(jié)果集

采用INNER JOIN優(yōu)化,JOIN子句里也優(yōu)先從索引獲取ID列表,然后直接關(guān)聯(lián)查詢獲得最終結(jié)果

mysql> SELECT -> a.uid, -> count(b.oid) AS total -> FROM -> table1 AS a -> LEFT JOIN table2 AS b ON a.uid = b.uid -> WHERE -> a. NAME = 'mike' -> GROUP BY -> a.uid -> HAVING -> count(b.oid) < 2 -> ORDER BY -> total DESC -> LIMIT 1;+-----+-------+| uid | total |+-----+-------+| ccc |  1 |+-----+-------+row in set (0.00 sec)

至此SQL的解析之旅就結(jié)束了,上圖總結(jié)一下:

 SQL語句,執(zhí)行,順序

參考書籍:

  • 《MySQL性能調(diào)優(yōu)與架構(gòu)實踐》
  • 《MySQL技術(shù)內(nèi)幕:SQL編程》

尾聲:

  嗯,到這里這一次的深入了解之旅就差不多真的結(jié)束了,雖然也不是很深入,只是一些東西將其東拼西湊在一起而已,參考了一些以前看過的書籍,大師之筆果然不一樣。而且在這過程中也是get到了蠻多東西的,最重要的是更進一步意識到,計算機軟件世界的宏大呀~

  另由于本人才疏學(xué)淺,其中難免存在紕漏錯誤之處,若發(fā)現(xiàn)勞煩告知修改,感謝~

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網(wǎng)的支持。


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产欧美一区二区精品性色超碰| 蜜桃视频在线观看网站| 97久久久久久久| 147欧美人体大胆444| 亚洲最新在线观看| 青青草综合在线| 超碰91在线观看| 久做在线视频免费观看| 日韩一区二区在线观看视频播放| 亚洲国产99精品国自产| 波多野结衣视频在线观看| 欧美日韩电影免费看| 91久久综合亚洲鲁鲁五月天| 国产美女福利视频| 国产亚洲精品久久久久久豆腐| 极品少妇xxxx精品少妇| 国产男女免费视频| 亚洲男女av一区二区| 一道本无吗dⅴd在线播放一区| 天天综合色天天综合| 色综合亚洲图丝熟| 99精品视频免费观看视频| 国产精品入口日韩视频大尺度| 婷婷精品久久久久久久久久不卡| 久久国产精品99国产| 国产网站欧美日韩免费精品在线观看| 熟女少妇a性色生活片毛片| 肉肉av福利一精品导航| 中文字幕资源网在线观看| 日本女人黄色片| 成全视频全集| 亚洲国产日韩a在线播放| 成片免费观看视频| 亚洲毛片av| 亚洲va男人天堂| 粉嫩av一区二区三区四区五区| 久久久影视精品| 婷婷中文字幕一区三区| 8888在线观看免费www| 伊人久久综合97精品| 久久久9色精品国产一区二区三区| 亚洲美女在线播放| 久久久九九九九| 91丝袜在线观看| 欧美一级精品大片| 91精品亚洲| 欧美精品一区免费| 亚洲在线观看| 97青娱国产盛宴精品视频| 国产精品久久a| 免费成人在线观看| 国产精品久久久亚洲第一牛牛| 国产伦精品一区二区三区视频女| 久久精品无码一区二区日韩av| 国产精品手机在线播放| 福利一区二区免费视频| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲欧美在线视频观看| 久久亚洲二区| 国产欧美一区视频| 久久综合激情| 亚洲xxx拳头交| 尤物yw午夜国产精品视频明星| 色偷偷免费视频| 亚洲18私人小影院| 初高中福利视频网站| 国产黄色高清视频| 57pao国产精品一区| 日韩欧美一区二区在线视频| 中文字幕久热精品视频免费| 在线播放一级片| 国产高清一区二区三区四区| 久久久精品91| 久久波多野结衣| 偷拍女澡堂一区二区三区| 性猛交ⅹxxx富婆video| 欧美日韩国产成人在线| 日本免费一区二区三区等视频| 爱福利一区二区| 成人午夜国产| 福利视频一区二区三区四区| 91高清视频在线观看| 国产精品久久不能| 精品无人乱码| 日韩精品福利视频| 国产 日韩 欧美 综合 一区| 99爱在线观看| 18video性欧美19sex高清| 91精品综合久久| 亚洲一区二区免费视频软件合集| 亚洲丝袜在线观看| 午夜丝袜av电影| 亚洲一区制服诱惑| 国产成人精品三级麻豆| 亚洲成年人在线| 欧美日韩高清一区二区不卡| 精品无码久久久久成人漫画| av免费播放网址| 免费看h片网站| 欧美a免费在线| 北条麻妃在线观看| 成人免费av资源| 农村末发育av片一区二区| 日韩欧美在线免费观看视频| h片在线观看视频免费免费| 91精品国产99久久久久久红楼| 欧美性做爰毛片| 精品女同一区二区三区在线观看| 婷婷婷国产在线视频| 国产91露脸中文字幕在线| 国产不卡免费视频| 中文字幕第一区| 欧美精品aa| 婷婷亚洲图片| 亚洲精品在线一区二区| 午夜精品久久久久| 久久久男人天堂| 国产女片a归国片aa| 夜夜夜操操操| 国产亚洲一区二区精品| 91精品国产入口在线| 凹凸成人精品亚洲精品密奴| 男人天堂av电影| 中韩乱幕日产无线码一区| 亚洲天堂免费看| 可以在线看黄的网站| 首页亚洲欧美制服丝腿| 99re这里只有精品视频首页| 日韩免费一区二区三区| 久久精品国产亚洲777| 欧美无乱码久久久免费午夜一区| 一线天自拍视频| 成人免费网站在线观看视频| 男女猛烈激情xx00免费视频| 国产精品久久久久77777丨| 成人无码av片在线观看| 在线精品视频免费播放| 国产精品亚洲综合久久| 亚洲精品大全| 农村少妇久久久久久久| 黄页网址在线观看| 懂色av粉嫩av浪潮av| 亚洲播播91| 操日韩av在线电影| 久久久久看片| 日韩日韩日韩日韩| 黄色小视频免费网站| 潘金莲一级淫片aaaaa免费看| 久久久久久av| 狠狠色噜噜狠狠狠8888米奇| 国产成人禁片在线观看| 波多野结衣办公室双飞| 99久久婷婷国产综合精品青牛牛| 婷婷色中文字幕| 高清av电影| 2018中文字幕第一页| 成人福利在线观看视频| 婷婷成人激情在线网| 欧美特级aaa| 国产v亚洲v天堂无码| 日韩理论片久久| 国内精品国产成人国产三级| 欧美一级免费看| 亚洲精品网站在线播放gif| 午夜精品福利一区二区三区av| 成人做爰www免费看视频网站| 在线综合亚洲| 欧美日韩人妻精品一区在线| 精品国产中文字幕第一页| 国产激情av在线| 亚洲欧洲日本一区二区三区| 91热精品视频| 北岛玲一区二区三区四区| 国产又黄又猛视频| 天天操天天碰| 久久野战av| 国产精品国产自产拍高清av王其| 91po在线观看91精品国产性色| 99综合精品久久| 欧美黑人xxxx猛牲大交| 欧美精品二区三区| 国产a级毛片一区| 国产哺乳奶水91在线播放| av免费在线免费观看| 九九热最新视频| 久久国产高清视频| 天堂社区在线视频| 欧美午夜激情小视频| 国产片乱18免费| 色噜噜狠狠一区二区三区狼国成人| 国产超级av在线| 欧美成人做性视频在线播放| 成人免费视频在线观看| xxx国产hd| 欧美日本高清| 99久久伊人精品影院| 青青青在线免费观看| 国产精品一级在线观看| 精品国产91九色蝌蚪| 国产精品妹子av| 国产免费一级| 国产欧美日韩精品一区二区三区| 先锋资源久久| 538在线一区二区精品国产| 色欲久久久天天天综合网| 久久久久久久伊人| 精品国产一区二区三区久久狼黑人| 亚洲激情婷婷| 中国国产一级毛片| 蜜臀av性久久久久蜜臀av麻豆| 好吊色视频一区二区三区| 老司机精品视频一区二区三区| 日韩av在线免费观看| 99久久精品费精品国产一区二区| 国产精品免费在线播放| 性色视频在线| 日韩经典中文字幕在线观看| 国产精品美女av| 日韩欧美一区二区在线视频| 国产 国语对白 露脸| 亚洲在线观看视频| 在线观看的日韩av| 久久爱www| 久久国产精品成人免费观看的软件| 亚欧美在线观看| 成人动漫免费在线观看| 超碰免费在线公开| 国产欧美第一页| 久久综合九色综合97_久久久| 在线免费看a| 午夜精品久久久久久久久久久久| 成人在线免费观看一区| 成人一级片在线观看| 性一交一黄一片| 在线免费高清一区二区三区| 亚洲天堂手机版| www.夜夜操.com| 黑人巨大40cm重口| 一区二区视频免费在线观看| 北条麻妃久久精品| 日本不良网站在线观看| 亚洲国产日韩一区二区| 中文一区一区三区免费在线观看| 欧美日韩和欧美的一区二区| 欧美系列电影免费观看| 中文字幕亚洲欧美日韩高清| 伊人久久亚洲美女图片| 美女隐私在线观看| 国产片侵犯亲女视频播放| 狠狠久久亚洲欧美专区| 中文字幕av免费| 毛片免费视频| 久久久免费观看视频| www.国产毛片| 欧美女人性生活视频| 91精品啪aⅴ在线观看国产| 国产羞羞视频在线观看| 欲色天天网综合久久| 成年人三级视频| 免费黄网在线看| 中文字幕久久熟女蜜桃| 99精品国产在热久久| 中国特级黄色片| 伊人av电影| 日韩午夜av在线| heyzo欧美激情| 又嫩又硬又黄又爽的视频| 国语对白在线刺激| 日韩理论电影中文字幕| 你懂的网站在线播放| 国产91精品久| 粉嫩老牛aⅴ一区二区三区| 日本福利午夜视频在线| 唐人社导航福利精品| 亚洲电影视频在线| 91视频观看免费| 色欲狠狠躁天天躁无码中文字幕| 欧美一二区在线观看| 久久久综合色| 欧美精品一区二区三区免费| 男女羞羞电影免费观看| 极品尤物一区二区| 空姐吹箫视频大全| 国产午夜精品视频免费不卡69堂| 国产麻豆剧果冻传媒视频杜鹃| 欧美视频一区二区三区在线观看| 中文字幕一区二区三区在线视频| 国产精品久久..4399| 免费人成黄页网站在线一区二区| 国内一区二区三区在线视频| 亚洲一区二区黄| 日本在线高清| 国产亚洲欧美日韩俺去了| 中文字幕精品—区二区日日骚| 精品国产丝袜高跟鞋| 在线观看视频h| 2020日本不卡一区二区视频| 国产成人啪精品午夜在线观看| 8x8ⅹ国产精品一区二区二区| 熟女高潮一区二区三区| 天天影视欧美综合在线观看| 久久久免费人体| 久草中文在线视频| 亚洲第一福利社区| 国精品日韩欧美一区二区三区| 西瓜成人精品人成网站| 日韩黄色免费电影| 91精品xxx在线观看| 久久免费小视频| 午夜啪啪免费视频| 国产极品模特精品一二| 欧美特黄a级高清免费大片a级| 日韩av在线免费播放| yiren22亚洲综合| 欧美成年人视频网站| 欧美xxxx性xxxxx高清| 手机在线色视频| 国产精品一区二区av白丝下载| 日韩一级高清毛片| 欧美亚洲系列| 亚洲看片免费| 国产网站欧美日韩免费精品在线观看| 青青草综合视频| 久久国产高清视频| 午夜日韩在线| 先锋影音欧美性受| 午夜精品久久久久久久99| 麻豆91精品91久久久|