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

Mysql體系化探討令人頭疼的JOIN運(yùn)算

 更新時(shí)間:2022年07月14日 14:07:23   作者:當(dāng)年的春天  
這篇文章主要介紹了體系化探討令人頭疼的JOIN運(yùn)算,本文將對JOIN運(yùn)算進(jìn)行體系化深入的探討,根據(jù)自己工作經(jīng)驗(yàn)及參考業(yè)界經(jīng)典案例,針對性地提出語法簡化和性能優(yōu)化的方法論,需要的朋友可以參考下

前言

  • 之前經(jīng)歷過從零到一初創(chuàng)項(xiàng)目,也有海量數(shù)據(jù)項(xiàng)目;總體來說當(dāng)項(xiàng)目在逐漸發(fā)展過程中如何構(gòu)建一個(gè)安全可靠,穩(wěn)定的數(shù)據(jù)存儲(chǔ)一直是項(xiàng)目中最核心、最重要、最關(guān)鍵部分,沒有之一
  • 接下來我會(huì)體系化輸出存儲(chǔ)系列文章;本篇文章我們先談一下數(shù)據(jù)中一個(gè)最令人頭疼的連接運(yùn)算—JOIN
  • JOIN 一直是SQL中的老大難問題。在關(guān)聯(lián)表稍多一點(diǎn)的時(shí)候,代碼書寫就變得很容易出錯(cuò)了且因?yàn)镴OIN語句的復(fù)雜,導(dǎo)致關(guān)聯(lián)查詢也一向是BI軟件的軟肋,幾乎沒有BI軟件能讓業(yè)務(wù)用戶順暢地完成多表關(guān)聯(lián)查詢。對于性能優(yōu)化也是,關(guān)聯(lián)表較多或者數(shù)據(jù)量大時(shí),JOIN的性能也很難得到提升
  • 基于以上,本文將對JOIN運(yùn)算進(jìn)行體系化深入的探討,根據(jù)自己工作經(jīng)驗(yàn)及參考業(yè)界經(jīng)典案例,針對性地提出語法簡化和性能優(yōu)化的方法論,希望對大家有所幫助

一圖總覽

在這里插入圖片描述

SQL中的JOIN

SQL是如何理解JOIN運(yùn)算

SQL對JOIN的定義

兩個(gè)集合(表)做笛卡爾積后再按某種條件過濾,寫出來的語法就是A JOIN B ON …。

  • 理論上講,笛卡爾積的結(jié)果集應(yīng)該是以兩個(gè)集合成員構(gòu)成的二元組作為成員,不過由于SQL中的集合也就是表,其成員總是有字段的記錄,而且也不支持泛型數(shù)據(jù)類型來描述成員為記錄的二元組,所以就簡單地把結(jié)果集處理成兩表記錄的字段合并后構(gòu)成的新記錄的集合。
  • 這也是JOIN一詞在英語中的原意(即把兩個(gè)記錄的字段連接起來),并沒有乘法(笛卡爾積)的意思。不過,把笛卡爾積成員理解成二元組還是合并字段的記錄,并不影響我們后續(xù)的討論。

JOIN定義

  • JOIN的定義中并沒有約定過濾條件的形式,理論上,只要結(jié)果集是兩個(gè)源集合笛卡爾積的子集,都是合理的JOIN運(yùn)算。
  • 例子:假設(shè)集合A={1,2},B={1,2,3},A JOIN B ON A<B的結(jié)果就是{(1,2),(1,3),(2,3)};A JOIN B ON A=B的結(jié)果是{(1,1),(2,2)}。

JOIN分類

  • 我們把過濾條件為等式的稱為等值JOIN,而不是等值連接的情況則稱為非等值JOIN。這兩個(gè)例子中,前者是非等值JOIN,后者是等值JOIN。

等值JOIN

  • 條件可能由多個(gè)有AND關(guān)系的等式構(gòu)成,語法形式A JOIN B ON A.ai=B.bi AND …,其中ai和bi分別是A和B的字段。
  • 有經(jīng)驗(yàn)的程序員都知道,現(xiàn)實(shí)中絕大多數(shù)JOIN都是等值JOIN,非等值JOIN要少見得多,而且大多數(shù)情況都可以轉(zhuǎn)換成等值JOIN來處理,所以我們在這里重點(diǎn)討論等值JOIN,并且后續(xù)討論中也主要使用表和記錄而不是集合和成員來舉例。

空值處理規(guī)則下分類

  • 根據(jù)對空值的處理規(guī)則,嚴(yán)格的等值JOIN又稱為INNER JOIN,還可以再衍生出LEFT JOIN和FULL JOIN,共有三種情況(RIGHT JOIN可以理解為LEFT JOIN的反向關(guān)聯(lián),不再單獨(dú)作為一種類型)。
  • 談?wù)揓OIN時(shí)一般還會(huì)根據(jù)兩個(gè)表中關(guān)聯(lián)記錄(也就是滿足過濾條件的二元組)的數(shù)量分為一對一、一對多、多對一以及多對多這幾種情況,這些常規(guī)術(shù)語在SQL和數(shù)據(jù)庫資料中都有介紹,這里就不再贅述了。

JOIN的實(shí)現(xiàn)

笨辦法

  • 最容易想到的簡單辦法就是按照定義做硬遍歷,不區(qū)分等值JOIN和非等值JOIN。設(shè)表A有n條記錄,B有m條記錄,要計(jì)算A JOIN B ON A.a=B.b時(shí),硬遍歷的復(fù)雜度會(huì)是nm,即要進(jìn)行nm次過濾條件的計(jì)算。
  • 顯然這種算法會(huì)比較慢。不過,支持多數(shù)據(jù)源的報(bào)表工具中有時(shí)就是用這種慢辦法實(shí)現(xiàn)關(guān)聯(lián)的,因?yàn)樵趫?bào)表中數(shù)據(jù)集的關(guān)聯(lián)關(guān)系(也就是JOIN中的過濾條件)會(huì)拆散定義在單元格的運(yùn)算式中,已經(jīng)看不出是多個(gè)數(shù)據(jù)集之間的JOIN運(yùn)算,也就只能用遍歷方法去計(jì)算這些關(guān)聯(lián)表達(dá)式了。

數(shù)據(jù)庫對于JOIN優(yōu)化

  • 對于等值JOIN,數(shù)據(jù)庫一般會(huì)采用HASH JOIN算法。即將關(guān)聯(lián)表的記錄按其關(guān)聯(lián)鍵(過濾條件中對應(yīng)相等的字段,即A.a和B.b)的HASH值分成若干組,將相同HASH值的記錄分到一組。如HASH值范圍是1…k,則將A和B表都分成k個(gè)子集A1,…,Ak和B1,…,Bk。Ai中記錄的關(guān)聯(lián)鍵a的HASH值是i,Bi中記錄的關(guān)聯(lián)鍵b的HASH值也是i,然后,只要分別在Ai和Bi之間做遍歷連接就可以了。
  • 因?yàn)镠ASH不同時(shí)字段值也必然不同,i!=j時(shí),Ai中記錄不可能和Bj中記錄發(fā)生關(guān)聯(lián)。如果Ai的記錄數(shù)是ni,Bi的記錄數(shù)是mi,則過濾條件的計(jì)算次數(shù)為SUM(ni*mi),最平均的情況時(shí),ni=n/k,mi=m/k,則總的復(fù)雜度只有原始硬遍歷手段的1/k,能有效地提高運(yùn)算性能!
  • 所以,多數(shù)據(jù)源關(guān)聯(lián)報(bào)表要提速的話,也需要在數(shù)據(jù)準(zhǔn)備階段做好關(guān)聯(lián),否則數(shù)據(jù)量稍大時(shí)性能就會(huì)急劇下降。
  • 不過,HASH函數(shù)并不總能保證平均分拆,在運(yùn)氣不好的時(shí)候可能會(huì)發(fā)生某一組特別大的情況,那樣性能提升效果就會(huì)差很多。而且還不能使用太復(fù)雜的HASH函數(shù),否則計(jì)算HASH的時(shí)間又變多了。
  • 當(dāng)數(shù)據(jù)量大到超過內(nèi)存時(shí),數(shù)據(jù)庫會(huì)使用HASH分堆的方法,算是HASH JOIN算法的推廣。遍歷A表和B表,將記錄按關(guān)聯(lián)鍵的HASH值拆分成若干小子集緩存到外存中,稱為分堆。然后再在對應(yīng)的堆之間做內(nèi)存JOIN運(yùn)算。同樣的道理,HASH值不同時(shí)鍵值也必然不同,關(guān)聯(lián)一定發(fā)生在對應(yīng)的堆之間。這樣就把大數(shù)據(jù)的JOIN轉(zhuǎn)換成若干小數(shù)據(jù)的JOIN了。
  • 但是類似地,HASH函數(shù)存在運(yùn)氣問題,有可能會(huì)發(fā)生某個(gè)分堆還特別大而無法裝入內(nèi)存,這時(shí)候就可能要進(jìn)行二次HASH分堆,即換一個(gè)HASH函數(shù)對這組太大的分堆再做一次HASH分堆算法。所以,外存JOIN運(yùn)算有可能出現(xiàn)多次緩存的現(xiàn)象,其運(yùn)算性能有一定的不可控性。

分布式系統(tǒng)下JOIN

  • 分布式系統(tǒng)下做JOIN也是類似的,根據(jù)關(guān)聯(lián)鍵的HASH值將記錄分發(fā)到各個(gè)節(jié)點(diǎn)機(jī)上,稱為Shuffle動(dòng)作,然后再分別做單機(jī)的JOIN。
  • 當(dāng)節(jié)點(diǎn)比較多的時(shí)候,造成的網(wǎng)絡(luò)傳輸量帶來的延遲會(huì)抵消多機(jī)分?jǐn)側(cè)蝿?wù)得到的好處,所以分布式數(shù)據(jù)庫系統(tǒng)通常有個(gè)節(jié)點(diǎn)數(shù)的極限,達(dá)到極限后,更多的節(jié)點(diǎn)并不能獲得更好的性能。

等值JOIN的剖析

三種等值JOIN:

外鍵關(guān)聯(lián)

  • 表A的某個(gè)字段和表B的主鍵字段關(guān)聯(lián)(所謂字段關(guān)聯(lián),就是前一節(jié)說過的在等值JOIN的過濾條件中要對應(yīng)相等的字段)。A表稱為事實(shí)表,B表稱為維表。A表中與B表主鍵關(guān)聯(lián)的字段稱為A指向B的外鍵,B也稱為A的外鍵表。
  • 這里說的主鍵是指邏輯上的主鍵,也就是在表中取值唯一、可以用于唯一某條記錄的字段(組),不一定在數(shù)據(jù)庫表上建立過主鍵。
  • 外鍵表是多對一的關(guān)系,且只有JOIN和LEFT JOIN,而FULL JOIN非常罕見。
  • 典型案例:商品交易表和商品信息表。
  • 顯然,外鍵關(guān)聯(lián)是不對稱的。事實(shí)表和維表的位置不能互換。

同維表

  • 表A的主鍵與表B的主鍵關(guān)聯(lián),A和B互稱為同維表。同維表是一對一的關(guān)系,JOIN、LEFT JOIN和FULL JOIN的情況都會(huì)有,不過在大多數(shù)數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)方案中,F(xiàn)ULL JOIN也相對少見。
  • 典型案例:員工表和經(jīng)理表。
  • 同維表之間是對稱的,兩個(gè)表的地位相同。同維表還構(gòu)成是等價(jià)關(guān)系,A和B是同維表,B和C是同維表,則A和C也是同維表。

主子表

  • 表A的主鍵與表B的部分主鍵關(guān)聯(lián),A稱為主表,B稱為子表。主子表是一對多的關(guān)系,只有JOIN和LEFT JOIN,不會(huì)有FULL JOIN。
  • 典型案例:訂單和訂單明細(xì)。
  • 主子表也是不對稱的,有明確的方向。
  • 在SQL的概念體系中并不區(qū)分外鍵表和主子表,多對一和一對多從SQL的觀點(diǎn)看來只是關(guān)聯(lián)方向不同,本質(zhì)上是一回事。確實(shí),訂單也可以理解成訂單明細(xì)的外鍵表。但是,我們在這里要把它們區(qū)分開,將來在簡化語法和性能優(yōu)化時(shí)將使用不同的手段。
  • 我們說,這三種JOIN已經(jīng)涵蓋了絕大多數(shù)等值JOIN的情況,甚至可以說幾乎全部有業(yè)務(wù)意義的等值JOIN都屬于這三類,把等值JOIN限定在這三種情況之中,幾乎不會(huì)減少其適應(yīng)范圍。
  • 仔細(xì)考察這三種JOIN,我們發(fā)現(xiàn)所有關(guān)聯(lián)都涉及主鍵,沒有多對多的情況,是不是可以不考慮這種情況?
  • 是的!多對多的等值JOIN幾乎沒有業(yè)務(wù)意義。
  • 如果兩個(gè)表JOIN時(shí)的關(guān)聯(lián)字段沒有涉及到任何主鍵,那就會(huì)發(fā)生多對多的情況,而這種情況幾乎一定還會(huì)有一個(gè)規(guī)模更大的表把這兩個(gè)表作為維表關(guān)聯(lián)起來。比如學(xué)生表和科目表在JOIN時(shí),會(huì)有個(gè)成績表把學(xué)生表和科目表作為維表,單純只有學(xué)生表和科目表的JOIN沒有業(yè)務(wù)意義。
  • 當(dāng)寫SQL語句時(shí)發(fā)現(xiàn)多對多的情況,那大概率是這個(gè)語句寫錯(cuò)了!或者數(shù)據(jù)有問題!這條法則用于排除JOIN錯(cuò)誤很有效。
  • 不過,我們一直在說“幾乎”,并沒有用完全肯定的說法,也就是說,多對多在非常罕見的情況下也會(huì)業(yè)務(wù)意義??膳e一例,用SQL實(shí)現(xiàn)矩陣乘法時(shí)會(huì)發(fā)生多對多的等值JOIN,具體寫法讀者可以自行補(bǔ)充。
  • 笛卡爾積再過濾這種JOIN定義,確實(shí)非常簡單,而簡單的內(nèi)涵將得到更大的外延,可以把多對多等值JOIN甚至非等值JOIN等都包括進(jìn)來。但是,過于簡單的內(nèi)涵無法充分體現(xiàn)出最常見等值JOIN的運(yùn)算特征。這會(huì)導(dǎo)致編寫代碼和實(shí)現(xiàn)運(yùn)算時(shí)就不能利用這些特征,在運(yùn)算較為復(fù)雜時(shí)(涉及關(guān)聯(lián)表較多以及有嵌套的情況),無論是書寫還是優(yōu)化都非常困難。而充分利用這些特征后,我們就能創(chuàng)造出更簡單的書寫形式并獲得更高效的運(yùn)算性能,后面的內(nèi)容中將會(huì)逐步加以說明。
  • 與其為了把罕見情況也被包括進(jìn)來而把運(yùn)算定義為更通用的形式,還不如把這些情況定義成另一種運(yùn)算更為合理。

JOIN的語法簡化

如何利用關(guān)聯(lián)都涉及主鍵這個(gè)特征來簡化JOIN的代碼書寫?

外鍵屬性化

例子,設(shè)有如下兩個(gè)表:

employee 員工表
    id 員工編號(hào)
    name 姓名
    nationality 國籍
    department 所屬部門

department 部門表
    id 部門編號(hào)
    name 部門名稱
    manager 部門經(jīng)理
  • employee表和department表的主鍵都是其中的id字段,employee表的department字段是指向department表的外鍵,department表的manager字段又是指向employee表的外鍵(因?yàn)榻?jīng)理也是個(gè)員工)。這是很常規(guī)的表結(jié)構(gòu)設(shè)計(jì)。
  • 現(xiàn)在我們想問一下:哪些美國籍員工有一個(gè)中國籍經(jīng)理?用SQL寫出來是個(gè)三表JOIN的語句:
SELECT A.* 
FROM employee A
JOIN department B ON A.department=B.id
JOIN employee C ON B.manager=C.id
WHERE A.nationality='USA' AND C.nationality='CHN'
  • 首先要FROM employee用于獲取員工信息,然后這個(gè)employee表要和department做JOIN獲取員工的部門信息,接著這個(gè)department表還要再和employee表JOIN要獲取經(jīng)理的信息,這樣employee表需要兩次參與JOIN,在SQL語句中要為它起個(gè)別名加以區(qū)分,整個(gè)句子就顯得比較復(fù)雜難懂。
  • 如果我們把外鍵字段直接理解成它關(guān)聯(lián)的維表記錄,就可以換一種寫法:
SELECT * FROM employee
WHERE nationality='USA' AND department.manager.nationality='CHN'

當(dāng)然,這不是標(biāo)準(zhǔn)的SQL語句了。

  • 第二個(gè)句子中粗體部分表示當(dāng)前員工的“所屬部門的經(jīng)理的國籍”。我們把外鍵字段理解成維表的記錄后,維表的字段被理解為外鍵的屬性,department.manager即是“所屬部門的經(jīng)理”,而這個(gè)字段在department中仍然是個(gè)外鍵,那么它對應(yīng)的維表記錄字段可以繼續(xù)理解為它的屬性,也就會(huì)有department.manager.nationality,即“所屬部門的經(jīng)理的國籍”。
  • 外鍵屬性化:這種對象式的理解方式即為外鍵屬性化,顯然比笛卡爾積過濾的理解方式要自然直觀得多。外鍵表JOIN時(shí)并不會(huì)涉及到兩個(gè)表的乘法,外鍵字段只是用于找到維鍵表中對應(yīng)的那條記錄,完全不會(huì)涉及到笛卡爾積這種有乘法特性的運(yùn)算。
  • 我們前面約定,外鍵關(guān)聯(lián)時(shí)時(shí)維表中關(guān)聯(lián)鍵必須是主鍵,這樣,事實(shí)表中每一條記錄的外鍵字段關(guān)聯(lián)的維表記錄就是唯一的,也就是說employee表中每一條記錄的department字段唯一關(guān)聯(lián)一條department表中的記錄,而department表中每一條記錄的manager字段也唯一關(guān)聯(lián)一條employee表中的記錄。這就保證了對于employee表中的每一條記錄,department.manager.nationality都有唯一的取值,可以被明確定義。
  • 但是,SQL對JOIN的定義中并沒有主鍵的約定,如果基于SQL的規(guī)則,就不能認(rèn)定與事實(shí)表中外鍵關(guān)聯(lián)的維表記錄有唯一性,有可能發(fā)生與多條記錄關(guān)聯(lián),對于employee表的記錄來講,department.manager.nationality沒有明確定義,就不能使用了。
  • 事實(shí)上,這種對象式寫法在高級(jí)語言(如C,Java)中很常見,在這類語言中,數(shù)據(jù)就是按對象方式存儲(chǔ)的。employee表中的department字段取值根本就是一個(gè)對象,而不是編號(hào)。其實(shí)許多表的主鍵取值本身并沒有業(yè)務(wù)意義,僅僅是為了區(qū)分記錄,而外鍵字段也僅僅是為了找到維表中的相應(yīng)記錄,如果外鍵字段直接是對象,就不需要再通過編號(hào)來標(biāo)識(shí)了。不過,SQL不能支持這種存儲(chǔ)機(jī)制,還要借助編號(hào)。
  • 我們說過外鍵關(guān)聯(lián)是不對稱的,即事實(shí)表和維表是不對等的,只能基于事實(shí)表去找維表字段,而不會(huì)有倒過來的情況。

同維表等同化

同維表的情況相對簡單,還是從例子開始,設(shè)有兩個(gè)表:

employee 員工表
    id 員工編號(hào)
    name 姓名
    salary 工資
    ...

manager 經(jīng)理表
    id 員工編號(hào)
    allowance 崗位津貼
    ....
  • 兩個(gè)表的主鍵都是id,經(jīng)理也是員工,兩表共用同樣的員工編號(hào),經(jīng)理會(huì)比普通員工多一些屬性,另用一個(gè)經(jīng)理表來保存。
  • 現(xiàn)在我們要統(tǒng)計(jì)所有員工(包括經(jīng)理)的總收入(加上津貼)。用SQL寫出來還是會(huì)用到JOIN:
SELECT employee.id, employee.name, employy.salary+manager.allowance
FROM employee
LEFT JOIN manager ON employee.id=manager.id

而對于兩個(gè)一對一的表,我們其實(shí)可以簡單地把它們看成一個(gè)表:

SELECT id,name,salary+allowance
FROM employee
  • 類似地,根據(jù)我們的約定,同維表JOIN時(shí)兩個(gè)表都是按主鍵關(guān)聯(lián)的,相應(yīng)記錄是唯一對應(yīng)的,salary+allowance對employee表中每條記錄都是唯一可計(jì)算的,不會(huì)出現(xiàn)歧義。這種簡化方式稱為同維表等同化。
  • 同維表之間的關(guān)系是對等的,從任何一個(gè)表都可以引用到其它同維表的字段。

子表集合化

訂單&訂單明細(xì)是典型的主子表:

Orders 訂單表
    id 訂單編號(hào)
    customer 客戶
    date 日期
    ...
OrderDetail 訂單明細(xì)
    id 訂單編號(hào)
    no 序號(hào)
    product 訂購產(chǎn)品
    price 價(jià)格
    ...

Orders表的主鍵是id,OrderDetail表中的主鍵是(id,no),前者的主鍵是后者的一部分。

現(xiàn)在我們想計(jì)算每張訂單的總金額。用SQL寫出來會(huì)是這樣:

SELECT Orders.id, Orders.customer, SUM(OrderDetail.price)
FROM Orders
JOIN OrderDetail ON Orders.id=OrderDetail.id
GROUP BY Orders.id, Orders.customer
  • 要完成這個(gè)運(yùn)算,不僅要用到JOIN,還需要做一次GROUP BY,否則選出來的記錄數(shù)太多。
  • 如果我們把子表中與主表相關(guān)的記錄看成主表的一個(gè)字段,那么這個(gè)問題也可以不再使用JOIN以及GROUP BY:
SELECT id, customer, OrderDetail.SUM(price)
FROM Orders
  • 與普通字段不同,OrderDetail被看成Orders表的字段時(shí),其取值將是一個(gè)集合,因?yàn)閮蓚€(gè)表是一對多的關(guān)系。所以要在這里使用聚合運(yùn)算把集合值計(jì)算成單值。這種簡化方式稱為子表集合化。
  • 這樣看待主子表關(guān)聯(lián),不僅理解書寫更為簡單,而且不容易出錯(cuò)。
  • 假如Orders表還有一個(gè)子表用于記錄回款情況:
OrderPayment 訂單回款表
    id 訂單編號(hào)
    date 回款日期
    amount 回款金額
    ....
  • 我們現(xiàn)在想知道那些訂單還在欠錢,也就是累計(jì)回款金額小于訂單總金額的訂單。
  • 簡單地把這三個(gè)表JOIN起來是不對的,OrderDetail和OrderPayment會(huì)發(fā)生多對多的關(guān)系,這就錯(cuò)了(回憶前面提過的多對多大概率錯(cuò)誤的說法)。這兩個(gè)子表要分別先做GROUP,再一起與Orders表JOIN起來才能得到正確結(jié)果,會(huì)寫成子查詢的形式:
SELECT Orders.id, Orders.customer,A.x,B.y
FROM Orders
LEFT JOIN ( SELECT id,SUM(price) x FROM OrderDetail GROUP BY id ) A 
    ON Orders.id=A.id
LEFT JOIN ( SELECT id,SUM(amount) y FROM OrderPayment GROUP BY id ) B
    ON Orders.id=B.id
WHERE A.x>B.y 

如果我們繼續(xù)把子表看成主表的集合字段,那就很簡單了:

SELECT id,customer,OrderDetail.SUM(price) x,OrderPayment.SUM(amount) y
FROM Orders WHERE x>y
  • 這種寫法也不容易發(fā)生多對多的錯(cuò)誤。
  • 主子表關(guān)系是不對等的,不過兩個(gè)方向的引用都有意義,上面談了從主表引用子表的情況,從子表引用主表則和外鍵表類似。
  • 我們改變對JOIN運(yùn)算的看法,摒棄笛卡爾積的思路,把多表關(guān)聯(lián)運(yùn)算看成是稍復(fù)雜些的單表運(yùn)算。這樣,相當(dāng)于把最常見的等值JOIN運(yùn)算的關(guān)聯(lián)消除了,甚至在語法中取消了JOIN關(guān)鍵字,書寫和理解都要簡單很多。

維度對齊語法

我們再回顧前面的雙子表例子的SQL:

SELECT Orders.id, Orders.customer, A.x, B.y
FROM Orders
LEFT JOIN (SELECT id,SUM(price) x FROM OrderDetail GROUP BY id ) A 
    ON Orders.id=A.id
LEFT JOIN (SELECT id,SUM(amount) y FROM OrderPayment GROUP BY id ) B
    ON Orders.id=B.id
WHERE A.x > B.y
  • 那么問題來了,這顯然是個(gè)有業(yè)務(wù)意義的JOIN,它算是前面所說的哪一類呢?
  • 這個(gè)JOIN涉及了表Orders和子查詢A與B,仔細(xì)觀察會(huì)發(fā)現(xiàn),子查詢帶有GROUP BY id的子句,顯然,其結(jié)果集將以id為主鍵。這樣,JOIN涉及的三個(gè)表(子查詢也算作是個(gè)臨時(shí)表)的主鍵是相同的,它們是一對一的同維表,仍然在前述的范圍內(nèi)。
  • 但是,這個(gè)同維表JOIN卻不能用前面說的寫法簡化,子查詢A,B都不能省略不寫。
  • 可以簡化書寫的原因:我們假定事先知道數(shù)據(jù)結(jié)構(gòu)中這些表之間的關(guān)聯(lián)關(guān)系。用技術(shù)術(shù)語的說法,就是知道數(shù)據(jù)庫的元數(shù)據(jù)(metadata)。而對于臨時(shí)產(chǎn)生的子查詢,顯然不可能事先定義在元數(shù)據(jù)中了,這時(shí)候就必須明確指定要JOIN的表(子查詢)。
  • 不過,雖然JOIN的表(子查詢)不能省略,但關(guān)聯(lián)字段總是主鍵。子查詢的主鍵總是由GROUP BY產(chǎn)生,而GROUP BY的字段一定要被選出用于做外層JOIN;并且這幾個(gè)子查詢涉及的子表是互相獨(dú)立的,它們之間不會(huì)再有關(guān)聯(lián)計(jì)算了,我們就可以把GROUP動(dòng)作以及聚合式直接放到主句中,從而消除一層子查詢:
SELECT Orders.id, Orders.customer, OrderDetail.SUM(price) x, OrderParyment.SUM(amount) y
FROM Orders 
LEFT JOIN OrderDetail GROUP BY id 
LEFT JOIN OrderPayment GROUP BY id
WHERE A.x > B.y
  • 這里的JOIN和SQL定義的JOIN運(yùn)算已經(jīng)差別很大,完全沒有笛卡爾積的意思了。而且,也不同于SQL的JOIN運(yùn)算將定義在任何兩個(gè)表之間,這里的JOIN,OrderDetail和OrderPayment以及Orders都是向一個(gè)共同的主鍵id對齊,即所有表都向某一套基準(zhǔn)維度對齊。而由于各表的維度(主鍵)不同,對齊時(shí)可能會(huì)有GROUP BY,在引用該表字段時(shí)就會(huì)相應(yīng)地出現(xiàn)聚合運(yùn)算。OrderDetail和OrderPayment甚至Orders之間都不直接發(fā)生關(guān)聯(lián),在書寫運(yùn)算時(shí)當(dāng)然就不用關(guān)心它們之間的關(guān)系,甚至不必關(guān)心另一個(gè)表是否存在。而SQL那種笛卡爾積式的JOIN則總要找一個(gè)甚至多個(gè)表來定義關(guān)聯(lián),一旦減少或修改表時(shí)就要同時(shí)考慮關(guān)聯(lián)表,增大理解難度。
  • 維度對齊:這種JOIN稱即為維度對齊,它并不超出我們前面說過的三種JOIN范圍,但確實(shí)在語法描述上會(huì)有不同,這里的JOIN不象SQL中是個(gè)動(dòng)詞,卻更象個(gè)連詞。而且,和前面三種基本JOIN中不會(huì)或很少發(fā)生FULL JOIN的情況不同,維度對齊的場景下FULL JOIN并不是很罕見的情況。
  • 雖然我們從主子表的例子抽象出維度對齊,但這種JOIN并不要求JOIN的表是主子表(事實(shí)上從前面的語法可知,主子表運(yùn)算還不用寫這么麻煩),任何多個(gè)表都可以這么關(guān)聯(lián),而且關(guān)聯(lián)字段也完全不必要是主鍵或主鍵的部分。
  • 設(shè)有合同表,回款表和發(fā)票表:
Contract 合同表
    id 合同編號(hào)
    date 簽訂日期
    customer 客戶
    price 合同金額
    ...

Payment 回款表
    seq 回款序號(hào)
    date 回款日期
    source 回款來源
    amount 金額
    ...

Invoice 發(fā)票表
    code 發(fā)票編號(hào)
    date 開票日期
    customer 客戶
    amount 開票金額
    ...

現(xiàn)在想統(tǒng)計(jì)每一天的合同額、回款額以及發(fā)票額,就可以寫成:

SELECT Contract.SUM(price), Payment.SUM(amount), Invoice.SUM(amount) ON date
FROM Contract GROUP BY date
FULL JOIN Payment GROUP BY date
FULL JOIN Invoice GROUP BY date
  • 這里需要把date在SELECT后單獨(dú)列出來表示結(jié)果集按日期對齊。
  • 這種寫法,不必關(guān)心這三個(gè)表之間的關(guān)聯(lián)關(guān)系,各自寫各自有關(guān)的部分就行,似乎這幾個(gè)表就沒有關(guān)聯(lián)關(guān)系,把它們連到一起的就是那個(gè)要共同對齊的維度(這里是date)。
  • 這幾種JOIN情況還可能混合出現(xiàn)。
  • 繼續(xù)舉例,延用上面的合同表,再有客戶表和銷售員表
Customer 客戶表
    id 客戶編號(hào)
    name 客戶名稱
    area 所在地區(qū)
    ...

Sales 銷售員表
    id 員工編號(hào)
    name 姓名
    area 負(fù)責(zé)地區(qū)
    ...
  • 其中Contract表中customer字段是指向Customer表的外鍵。
  • 現(xiàn)在我們想統(tǒng)計(jì)每個(gè)地區(qū)的銷售員數(shù)量及合同額:
SELECT Sales.COUNT(1), Contract.SUM(price) ON area
FROM Sales GROUP BY area
FULL JOIN Contract GROUP BY customer.area
  • 維度對齊可以和外鍵屬性化的寫法配合合作。
  • 這些例子中,最終的JOIN都是同維表。事實(shí)上,維度對齊還有主子表對齊的情況,不過相對罕見,我們這里就不深入討論了。
  • 另外,目前這些簡化語法仍然是示意性,需要在嚴(yán)格定義維度概念之后才能相應(yīng)地形式化,成為可以解釋執(zhí)行的句子。
  • 我們把這種簡化的語法稱為DQL(Dimensional Query Languange),DQL是以維度為核心的查詢語言。我們已經(jīng)將DQL在工程上做了實(shí)現(xiàn),并作為潤乾報(bào)表的DQL服務(wù)器發(fā)布出來,它能將DQL語句翻譯成SQL語句執(zhí)行,也就是可以在任何關(guān)系數(shù)據(jù)庫上運(yùn)行。
  • 對DQL理論和應(yīng)用感興趣的讀者可以關(guān)注乾學(xué)院上發(fā)布的論文和相關(guān)文章。

解決關(guān)聯(lián)查詢

多表JOIN問題

  • 我們知道,SQL允許用WHERE來寫JOIN運(yùn)算的過濾條件(回顧原始的笛卡爾積式的定義),很多程序員也習(xí)慣于這么寫。
  • 當(dāng)JOIN表只有兩三個(gè)的時(shí)候,那問題還不大,但如果JOIN表有七八個(gè)甚至十幾個(gè)的時(shí)候,漏寫一個(gè)JOIN條件是很有可能的。而漏寫了JOIN條件意味著將發(fā)生多對多的完全叉乘,而這個(gè)SQL卻可以正常執(zhí)行,會(huì)有以下兩點(diǎn)危害:
    • 一方面計(jì)算結(jié)果會(huì)出錯(cuò):回憶一下以前說過的,發(fā)生多對多JOIN時(shí),大概率是語句寫錯(cuò)了
    • 另一方面,如果漏寫條件的表很大,笛卡爾積的規(guī)模將是平方級(jí)的,這極有可能把數(shù)據(jù)庫直接“跑死”!

簡化JOIN運(yùn)算好處:

  • 一個(gè)直接的效果顯然是讓語句書寫和理解更容易
  • 外鍵屬性化、同維表等同化和子表集合化方案直接消除了顯式的關(guān)聯(lián)運(yùn)算,也更符合自然思維
  • 維度對齊則可讓程序員不再關(guān)心表間關(guān)系,降低語句的復(fù)雜度
  • 簡化JOIN語法的好處不僅在于此,還能夠降低出錯(cuò)率,采用簡化后的JOIN語法,就不可能發(fā)生漏寫JOIN條件的情況了。因?yàn)閷OIN的理解不再是以笛卡爾積為基礎(chǔ),而且設(shè)計(jì)這些語法時(shí)已經(jīng)假定了多對多關(guān)聯(lián)沒有業(yè)務(wù)意義,這個(gè)規(guī)則下寫不出完全叉乘的運(yùn)算。
  • 對于多個(gè)子表分組后與主表對齊的運(yùn)算,在SQL中要寫成多個(gè)子查詢的形式。但如果只有一個(gè)子表時(shí),可以先JOIN再GROUP,這時(shí)不需要子查詢。有些程序員沒有仔細(xì)分析,會(huì)把這種寫法推廣到多個(gè)子表的情況,也先JOIN再GROUP,可以避免使用子查詢,但計(jì)算結(jié)果是錯(cuò)誤的。
  • 使用維度對齊的寫法就不容易發(fā)生這種錯(cuò)誤了,無論多少個(gè)子表,都不需要子查詢,一個(gè)子表和多個(gè)子表的寫法完全相同。

關(guān)聯(lián)查詢

  • 重新看待JOIN運(yùn)算,最關(guān)鍵的作用在于實(shí)現(xiàn)關(guān)聯(lián)查詢。
  • 當(dāng)前BI產(chǎn)品是個(gè)熱門,各家產(chǎn)品都宣稱能夠讓業(yè)務(wù)人員拖拖拽拽就完成想要的查詢報(bào)表。但實(shí)際應(yīng)用效果會(huì)遠(yuǎn)不如人意,業(yè)務(wù)人員仍然要經(jīng)常求助于IT部門。造成這個(gè)現(xiàn)象的主要原因在于大多數(shù)業(yè)務(wù)查詢都是有過程的計(jì)算,本來也不可能拖拽完成。但是,也有一部分業(yè)務(wù)查詢并不涉及多步過程,而業(yè)務(wù)人員仍然難以完成。
  • 這就是關(guān)聯(lián)查詢,也是大多數(shù)BI產(chǎn)品的軟肋。在之前的文章中已經(jīng)講過為什么關(guān)聯(lián)查詢很難做,其根本原因就在于SQL對JOIN的定義過于簡單。
  • 結(jié)果,BI產(chǎn)品的工作模式就變成先由技術(shù)人員構(gòu)建模型,再由業(yè)務(wù)人員基于模型進(jìn)行查詢。而所謂建模,就是生成一個(gè)邏輯上或物理上的寬表。也就是說,建模要針對不同的關(guān)聯(lián)需求分別實(shí)現(xiàn),我們稱之為按需建模,這時(shí)候的BI也就失去敏捷性了。
  • 但是,如果我們改變了對JOIN運(yùn)算的看法,關(guān)聯(lián)查詢可以從根本上得到解決?;貞浨懊嬷v過的三種JOIN及其簡化手段,我們事實(shí)上把這幾種情況的多表關(guān)聯(lián)都轉(zhuǎn)化成了單表查詢,而業(yè)務(wù)用戶對于單表查詢并沒有理解障礙。無非就是表的屬性(字段)稍復(fù)雜了一些:可能有子屬性(外鍵字段指向的維表并引用其字段),子屬性可能還有子屬性(多層的維表),有些字段取值是集合而非單值(子表看作為主表的字段)。發(fā)生互相關(guān)聯(lián)甚至自我關(guān)聯(lián)也不會(huì)影響理解(前面的中國經(jīng)理的美國員工例子就是互關(guān)聯(lián)),同表有相同維度當(dāng)然更不礙事(各自有各自的子屬性)。
  • 在這種關(guān)聯(lián)機(jī)制下,技術(shù)人員只要一次性把數(shù)據(jù)結(jié)構(gòu)(元數(shù)據(jù))定義好,在合適的界面下(把表的字段列成有層次的樹狀而不是常規(guī)的線狀),就可以由業(yè)務(wù)人員自己實(shí)現(xiàn)JOIN運(yùn)算,不再需要技術(shù)人員的參與。數(shù)據(jù)建模只發(fā)生于數(shù)據(jù)結(jié)構(gòu)改變的時(shí)刻,而不需要為新的關(guān)聯(lián)需求建模,這也就是非按需建模,在這種機(jī)制支持下的BI才能擁有足夠的敏捷性。

外鍵預(yù)關(guān)聯(lián)

  • 我們再來研究如何利用JOIN的特征實(shí)現(xiàn)性能優(yōu)化,這些內(nèi)容的細(xì)節(jié)較多,我們挑一些易于理解的情況來舉例,更完善的連接提速算法可以參考乾學(xué)院上的《性能優(yōu)化》圖書和SPL學(xué)習(xí)資料中的性能優(yōu)化專題文章。

全內(nèi)存下外鍵關(guān)聯(lián)情況

設(shè)有兩個(gè)表:

customer 客戶信息表
    key 編號(hào)
    name 名稱
    city 城市
    ...

orders 訂單表
    seq 序號(hào)
    date 日期
    custkey 客戶編號(hào)
    amount 金額
    ...
  • 其中orders表中的custkey是指向customer表中key字段的外鍵,key是customer表的主鍵。
  • 現(xiàn)在我們各個(gè)城市的訂單總額(為簡化討論,就不再設(shè)定條件了),用SQL寫出來:
SELECT customer.city, SUM(orders.amount)
FROM orders
JOIN customer ON orders.custkey=customer.key
GROUP BY customer.city
  • 數(shù)據(jù)庫一般會(huì)使用HASH JOIN算法,需要分別兩個(gè)表中關(guān)聯(lián)鍵的HASH值并比對。
  • 我們用前述的簡化的JOIN語法(DQL)寫出這個(gè)運(yùn)算:
SELECT custkey.city, SUM(amount)
FROM orders
GROUP BY custkey.city
  • 這個(gè)寫法其實(shí)也就預(yù)示了它還可以有更好的優(yōu)化方案,下面來看看怎樣實(shí)現(xiàn)。
  • 如果所有數(shù)據(jù)都能夠裝入內(nèi)存,我們可以實(shí)現(xiàn)外鍵地址化。
  • 將事實(shí)表orders中的外鍵字段custkey,轉(zhuǎn)換成維表customer中關(guān)聯(lián)記錄的地址,即orders表的custkey的取值已經(jīng)是某個(gè)customer表中的記錄,那么就可以直接引用記錄的字段進(jìn)行計(jì)算了。
  • 用SQL無法描述這個(gè)運(yùn)算的細(xì)節(jié)過程,我們使用SPL來描述、并用文件作為數(shù)據(jù)源來說明計(jì)算過程:
 A
1=file(“customer.btx”).import@b()
2>A1.keys@i(key)
3=file(“orders.btx”).import@b()
4>A3.switch(custkey,A1)
5=A3.groups(custkey.city;sum(amount))
  • A1讀出客戶表,A2為客戶表設(shè)置主鍵并建立索引。
  • A3讀出訂單表,A4的動(dòng)作是將A3的外鍵字段custkey轉(zhuǎn)換成對應(yīng)的A1的記錄,執(zhí)行完后,訂單表字段custkey將變成客戶表的某條記錄。A2建了索引能讓switch更快,因?yàn)橥ǔJ聦?shí)表遠(yuǎn)大于維表,這個(gè)索引能被復(fù)用很多次。
  • A5就可以執(zhí)行分組匯總了,遍歷訂單表時(shí),由于custkey字段取值現(xiàn)在已經(jīng)是一條記錄,那么可以直接用.操作符引用其字段了,custkey.city就可以正常執(zhí)行。
  • 完成A4中的switch動(dòng)作之后,內(nèi)存中事實(shí)表A3的custkey字段存儲(chǔ)內(nèi)容已經(jīng)是維表A1的某條記錄的地址,這個(gè)動(dòng)作即稱為外鍵地址化。這時(shí)候引用維表字段時(shí),可以直接取出,而不需要再用外鍵值在A1中查找,相當(dāng)于在常數(shù)時(shí)間內(nèi)就能取到維表的字段,避免了HASH值計(jì)算和比對。
  • 不過,A2建主鍵索引一般也會(huì)用HASH辦法,對key計(jì)算HASH值,A4轉(zhuǎn)換地址時(shí)也是計(jì)算custkey的HASH值與A2的HASH索引表對比。如果只做一次關(guān)聯(lián)運(yùn)算,地址化的方案和傳統(tǒng)HASH分段方案的計(jì)算量基本上一樣,沒有根本優(yōu)勢。
  • 但不同的是,如果數(shù)據(jù)能在內(nèi)存中放下,這個(gè)地址一旦轉(zhuǎn)換之后可以復(fù)用,也就是說A1到A4只要做一次,下次再做關(guān)于這兩個(gè)字段的關(guān)聯(lián)運(yùn)算時(shí)就不必再計(jì)算HASH值和比對了,性能就能大幅提高。
  • 能夠這樣做,正是利用了前面說過的外鍵關(guān)聯(lián)在維表這一方具有的唯一性,一個(gè)外鍵字段值只會(huì)唯一對應(yīng)一條維表記錄,可以把每個(gè)custkey轉(zhuǎn)換成它唯一對應(yīng)的那條A1的記錄。而延用SQL中對JOIN的定義,就不能假定外鍵指向記錄的唯一性,無法使用這種表示法。而且SQL也沒有記錄地址這種數(shù)據(jù)類型,結(jié)果會(huì)導(dǎo)致每次關(guān)聯(lián)時(shí)都要計(jì)算HASH值并比對。
  • 而且,如果事實(shí)表中有多個(gè)外鍵分別指向多個(gè)維表,傳統(tǒng)的HASH分段JOIN方案每次只能解析掉一個(gè),有多個(gè)JOIN要執(zhí)行多遍動(dòng)作,每次關(guān)聯(lián)后都需要保持中間結(jié)果供下一輪使用,計(jì)算過程復(fù)雜得多,數(shù)據(jù)也會(huì)被遍歷多次。而外鍵地址化方案在面對多個(gè)外鍵時(shí),只要對事實(shí)表遍歷一次,沒有中間結(jié)果,計(jì)算過程要清晰很多。
  • 還有一點(diǎn),內(nèi)存本來是很適合并行計(jì)算的,但HASH分段JOIN算法卻不容易并行。即使把數(shù)據(jù)分段并行計(jì)算HASH值,但要把相同HASH值的記錄歸聚到一起供下一輪比對,還會(huì)發(fā)生共享資源搶占的事情,這將犧牲很多并行計(jì)算的優(yōu)勢。而外鍵式JOIN模型下,關(guān)聯(lián)兩表的地位不對等,明確區(qū)分出維表和事實(shí)表后,只要簡單地將事實(shí)表分段就可以并行計(jì)算。
  • 將HASH分段技術(shù)參照外鍵屬性方案進(jìn)行改造后,也能一定程度地改善多外鍵一次解析和并行能力,有些數(shù)據(jù)庫能在工程層面上實(shí)施這種優(yōu)化。不過,這種優(yōu)化在只有兩個(gè)表JOIN時(shí)問題不大,在有很多表及各種JOIN混在一起時(shí),數(shù)據(jù)庫并不容易識(shí)別出應(yīng)當(dāng)把哪個(gè)表當(dāng)作事實(shí)表去并行遍歷、而把其它表當(dāng)作維表建立HASH索引,這時(shí)優(yōu)化并不總是有效的。所以我們經(jīng)常會(huì)發(fā)現(xiàn)當(dāng)JOIN的表變多時(shí)性能會(huì)急劇下降的現(xiàn)象(常常到四五個(gè)表時(shí)就會(huì)發(fā)生,結(jié)果集并無顯著增大)。而從JOIN模型上引入外鍵概念后,將這種JOIN專門處理時(shí),就總能分清事實(shí)表和維表,更多的JOIN表只會(huì)導(dǎo)致性能的線性下降。
  • 內(nèi)存數(shù)據(jù)庫是當(dāng)前比較火熱的技術(shù),但上述分析表明,采用SQL模型的內(nèi)存數(shù)據(jù)庫在JOIN運(yùn)算上是很難快起來的!

進(jìn)一步的外鍵關(guān)聯(lián)

  • 我們繼續(xù)討論外鍵JOIN,并延用上一節(jié)的例子。
  • 當(dāng)數(shù)據(jù)量大到無法全部放進(jìn)內(nèi)存時(shí),前述的地址化方法就不再有效了,因?yàn)樵谕獯鏌o法保存事先算好的地址。
  • 一般來講,外鍵指向的維表容量較小,而不斷增長的事實(shí)表要大得多。如果內(nèi)存還能把維表放下的話,我們可以采用臨時(shí)指向的方法來處理外鍵。
 A
1=file(“customer.btx”).import@b()
2=file(“orders.btx”).cursor@b()
3>A2.switch(custkey,A1:#)
4=A2.groups(custkey.city;sum(amount))
  • 前兩步與全內(nèi)存時(shí)相同,第4步的地址轉(zhuǎn)換是邊讀入邊進(jìn)行的,而且轉(zhuǎn)換結(jié)果無法保留復(fù)用,下次再做關(guān)聯(lián)時(shí)還要再計(jì)算HASH和比對,性能要比全內(nèi)存的方案差。計(jì)算量方面,比HASH JOIN算法少了一次維表的HASH值計(jì)算,這個(gè)維表如果經(jīng)常被復(fù)用時(shí)會(huì)占些便宜,但因?yàn)榫S表相對較小,總體優(yōu)勢并不算大。不過,這個(gè)算法同樣具有全內(nèi)存算法可以一次解析全部外鍵以及易于并行的特點(diǎn),在實(shí)際場景下比HASH JOIN算法仍有較大的性能優(yōu)勢。

外鍵序號(hào)化

在這個(gè)算法基礎(chǔ)上,我們還可以做個(gè)變種:外鍵序號(hào)化。

如果我們能把維表的主鍵都轉(zhuǎn)換成從1開始的自然數(shù),那么我們就可以用序號(hào)直接定位維表記錄,就不需要計(jì)算和比對HASH值,這樣就可以獲得類似全內(nèi)存下地址化的性能了。

 A
1=file(“customer.btx”).import@b()
2=file(“orders.btx”).cursor@b()
3>A2.switch(custkey,A1:#)
4=A2.groups(custkey.city;sum(amount))

 

  • 維表主鍵是序號(hào)時(shí)就不需要再做原來建HASH索引的第2步了。
  • 外鍵序號(hào)化本質(zhì)上相當(dāng)于在外存實(shí)現(xiàn)地址化。這種方案需要把事實(shí)表中的外鍵字段轉(zhuǎn)換成序號(hào),這類似在全內(nèi)存運(yùn)算時(shí)地址化的過程,這個(gè)預(yù)計(jì)算也可以得到復(fù)用。需要注意的是,維表發(fā)生重大變化時(shí),需要同步整理事實(shí)表的外鍵字段,否則可能對應(yīng)錯(cuò)位。不過一般維表變化頻度低,而且大多數(shù)動(dòng)作是追加和修改而非刪除,需要重整事實(shí)表的情況并不多。工程上的細(xì)節(jié)處理也可以再參考乾學(xué)院中的資料。
  • SQL使用了無序集合的概念,即使我們事先把外鍵序號(hào)化了,數(shù)據(jù)庫也無法利用這個(gè)特點(diǎn),不能在無序集合上使用序號(hào)快速定位的機(jī)制,只能使用索引查找,而且數(shù)據(jù)庫并不知道外鍵被序號(hào)化了,仍然會(huì)去計(jì)算HASH值和比對。
  • 如果維表也大到內(nèi)存裝不下呢?
  • 我們仔細(xì)分析上面的算法會(huì)發(fā)現(xiàn),過程中對于事實(shí)表的訪問是連續(xù)的,但對于維表的訪問則是隨機(jī)的。我們以前討論硬盤的性能特征時(shí)談到過,外存不適合隨機(jī)訪問,所以外存中的維表不能再使用上述算法了。
  • 外存中的維表可以事先按主鍵排序存儲(chǔ),這樣我們就可以繼續(xù)利用維表關(guān)聯(lián)鍵是主鍵的特征來優(yōu)化性能。
  • 如果事實(shí)表很小,可以在內(nèi)存裝放下,那么用外鍵去關(guān)聯(lián)維表記錄實(shí)際上會(huì)變成一個(gè)(批量)外存查找動(dòng)作。只要維表上針對主鍵建有索引,也可以很快地查找,這樣可以避免遍歷大維表,獲得更好的性能。這種算法也可以同時(shí)解析多個(gè)外鍵。SQL不區(qū)分維表和事實(shí)表,面對一大一小兩個(gè)表時(shí),優(yōu)化過的HASH JOIN不會(huì)再做分堆緩存,通常會(huì)把小表讀入內(nèi)存而去遍歷大表,這樣仍然會(huì)有遍歷大維表的動(dòng)作,性能會(huì)比剛才說的外存查找算法差得多。
  • 如果事實(shí)表也很大,則可以使用單邊分堆的算法。因?yàn)榫S表已經(jīng)按關(guān)聯(lián)鍵(即主鍵)有序,可以方便地邏輯上分成若干段并取出每一段的邊界值(每一段主鍵的最大最小值),然后將事實(shí)表按這些邊界值做分堆,每一堆分別和維表的每一段再做關(guān)聯(lián)就可以了。過程中只需要對事實(shí)表單邊做物理分堆緩存,維表不需要再做物理分堆緩存,而且不使用HASH函數(shù),直接用分段,不可能會(huì)出現(xiàn)HASH函數(shù)運(yùn)氣不好導(dǎo)致二次分堆,性能是可控的。而數(shù)據(jù)庫的HASH分堆算法會(huì)將兩個(gè)大表都做物理分堆緩存,也就是雙邊分堆,還可能出現(xiàn)HASH函數(shù)運(yùn)氣不好導(dǎo)致二次分堆的現(xiàn)象,性能要比單邊分堆差得多,還不可控。

借助集群的力量解決大維表問題。

  • 一臺(tái)機(jī)器的內(nèi)存裝不下,可以多搞幾臺(tái)機(jī)器來裝下,把維表按主鍵值分段存放在多臺(tái)機(jī)器上形成集群維表,然后就可以繼續(xù)使用上面針對內(nèi)存維表的算法了,也能獲得一次解析多個(gè)外鍵和易于并行的好處。同樣地,集群維表也可以使用序號(hào)化的技術(shù)。這種算法下,事實(shí)表不需要被傳輸,產(chǎn)生的網(wǎng)絡(luò)傳輸量并不大,也不需要節(jié)點(diǎn)本地緩存數(shù)據(jù)。而SQL體系下不能區(qū)分出維表,HASH拆分方法要將兩個(gè)表都做Shuffle動(dòng)作,網(wǎng)絡(luò)傳播量要大得多。
  • 這些算法的細(xì)節(jié)仍有些復(fù)雜,這里限于篇幅無法詳細(xì)解釋,有興趣的讀者可以去乾學(xué)院的資料查閱。

有序歸并

同維表&主子表的JOIN優(yōu)化提速手段

  • 我們前面討論過,HASH JOIN算法的計(jì)算復(fù)雜度(即關(guān)聯(lián)鍵的比較次數(shù))是SUM(nimi),比全遍歷的復(fù)雜度nm要小很多,不過要看HASH函數(shù)的運(yùn)氣。
  • 如果這兩個(gè)表都對關(guān)聯(lián)鍵有序,那么我們就可以使用歸并算法來處理關(guān)聯(lián),這時(shí)的復(fù)雜度是n+m;在n和m都較大的時(shí)候(一般都會(huì)遠(yuǎn)大于HASH函數(shù)的取值范圍),這個(gè)數(shù)也會(huì)遠(yuǎn)小于HASH JOIN算法的復(fù)雜度。歸并算法的細(xì)節(jié)有很多材料介紹,這里就不再贅述了。
  • 但是,外鍵JOIN時(shí)不能使用這個(gè)辦法,因?yàn)槭聦?shí)表上可能有多個(gè)要參與關(guān)聯(lián)的外鍵字段,不可能讓同一個(gè)事實(shí)表同時(shí)針對多個(gè)字段都有序。
  • 同維表和主子表卻可以!因?yàn)橥S表和主子表總是針對主鍵或主鍵的一部分關(guān)聯(lián),我們可以事先把這些關(guān)聯(lián)表的數(shù)據(jù)按其主鍵排序。排序的成本雖然較高,但是一次性的。一旦完成了排序,以后就可以總是使用歸并算法實(shí)現(xiàn)JOIN,性能可以提高很多。
  • 這還是利用了關(guān)聯(lián)鍵是主鍵(及其部分)的特征。
  • 有序歸并對于大數(shù)據(jù)特別有效。像訂單及其明細(xì)這種主子表是不斷增長的事實(shí)表,時(shí)間長了常常會(huì)積累得非常大,很容易超出內(nèi)存容量。
  • 外存大數(shù)據(jù)的HASH分堆算法需要產(chǎn)生很多緩存,數(shù)據(jù)在外存中被讀兩次寫一次,IO開銷很大。而歸并算法時(shí),兩個(gè)表的數(shù)據(jù)都只要讀一次就行了,沒有寫。不僅是CPU的計(jì)算量減少,外存的IO量也大幅下降。而且,執(zhí)行歸并算法需要的內(nèi)存很少,只要在內(nèi)存中為每個(gè)表保持?jǐn)?shù)條緩存記錄就可以了,幾乎不會(huì)影響其它并發(fā)任務(wù)對內(nèi)存的需求。而HASH分堆需要較大內(nèi)存,每次讀出更多數(shù)據(jù),以減少分堆的次數(shù)。
  • SQL采用笛卡爾積定義的JOIN運(yùn)算不區(qū)分JOIN類型,不假定某些JOIN總是針對主鍵的,就沒辦法從算法層面上利用這一特點(diǎn),只能在工程層面進(jìn)行優(yōu)化。有些數(shù)據(jù)庫會(huì)檢查數(shù)據(jù)表在物理存儲(chǔ)上是否針對關(guān)聯(lián)字段有序,如果有序則采用歸并算法,但基于無序集合概念的關(guān)系數(shù)據(jù)庫不會(huì)刻意保證數(shù)據(jù)的物理有序性,許多操作都會(huì)破壞歸并算法的實(shí)施條件。使用索引可以實(shí)現(xiàn)數(shù)據(jù)的邏輯有序,但物理無序時(shí)的遍歷效率還是會(huì)大打折扣。
  • 有序歸并的前提是將數(shù)據(jù)按主鍵排序,而這類數(shù)據(jù)常常會(huì)不斷追加,原則上每次追加后就要再次排序,而我們知道大數(shù)據(jù)排序成本通常很高,這是否會(huì)導(dǎo)致追加數(shù)據(jù)難度很大呢?其實(shí),追加數(shù)據(jù)再加入的過程也是個(gè)有序歸并,把新增數(shù)據(jù)單獨(dú)排序后和已有序的歷史數(shù)據(jù)歸并,復(fù)雜度是線性的,相當(dāng)于把所有數(shù)據(jù)重寫一次,而不像常規(guī)的大數(shù)據(jù)排序需要緩存式寫出再讀入。在工程上做些優(yōu)化動(dòng)作還可以做到不必每次都全部重寫,進(jìn)一步提高維護(hù)效率。這些在乾學(xué)院上都有介紹。

分段并行

  • 有序歸并的好處還在于易于分段并行。
  • 現(xiàn)代計(jì)算機(jī)的都有多核CPU,SSD硬盤也有較強(qiáng)的并發(fā)能力,使用多線程并行計(jì)算就能夠顯著提高性能。但傳統(tǒng)的HASH分堆技術(shù)實(shí)現(xiàn)并行比較困難,多線程做HASH分堆時(shí)需要同時(shí)向某個(gè)分堆寫出數(shù)據(jù),造成共享資源沖突;而第二步實(shí)現(xiàn)某組分堆關(guān)聯(lián)時(shí)又會(huì)消費(fèi)大量內(nèi)存,無法讓實(shí)施較大的并行數(shù)量。
  • 使用有序歸并實(shí)現(xiàn)并行計(jì)算時(shí)需要把數(shù)據(jù)分成多段,單個(gè)表分段比較簡單,但兩個(gè)關(guān)聯(lián)表分段時(shí)必須同步對齊,否則歸并時(shí)兩個(gè)表數(shù)據(jù)錯(cuò)位了,就無法得出正確的計(jì)算結(jié)果,而數(shù)據(jù)有序就可以保證高性能的同步對齊分段。
  • 先把主表(同維表則取較大的即可,其它討論不影響)平均分成若干段,讀出每段第一條記錄的主鍵值,然后用這些鍵值到子表中用二分法尋找定位(因?yàn)橐灿行颍?,從而獲得子表的分段點(diǎn)。這樣可以保證主子表的分段是同步對齊的。
  • 因?yàn)殒I值有序,所以主表每段的記錄鍵值都屬于某個(gè)連續(xù)區(qū)間,鍵值在區(qū)間外的記錄不會(huì)在這一段,鍵值在區(qū)間內(nèi)的記錄一定在這一段,子表對應(yīng)分段的記錄鍵值也有這個(gè)特性,所以不會(huì)發(fā)生錯(cuò)位情況;而同樣因?yàn)殒I值有序,才可以在子表中執(zhí)行高效的二分查找迅速定位出分段點(diǎn)。即數(shù)據(jù)有序保證了分段的合理性及高效性,這樣就可以放心地執(zhí)行并行算法了。
  • 主子表這種主鍵關(guān)聯(lián)的關(guān)系還有一個(gè)特征,就是子表只會(huì)和一個(gè)主表在主鍵上關(guān)聯(lián)(其實(shí)同維表也有,但用主子表容易解釋),它不會(huì)有多個(gè)相互無關(guān)的主表(可能有主表的主表)。這時(shí)候,還可以使用一體化存儲(chǔ)的機(jī)制,把子表記錄作為主表的字段值去存儲(chǔ)。這樣,一方面減少了存儲(chǔ)量(關(guān)聯(lián)鍵只要存儲(chǔ)一次),又相當(dāng)于預(yù)先做好了關(guān)聯(lián),不需要再做比對了。對于大數(shù)據(jù),就能獲得更好的性能。
  • 我們已經(jīng)將上述這些性能優(yōu)化手段在集算器SPL中實(shí)現(xiàn)并在實(shí)際場景用得到了應(yīng)用,也取得了非常好的效果。SPL目前已經(jīng)開源,讀者可以去數(shù)速公司或潤乾公司官網(wǎng)及論壇下載并獲得更多資料。

總結(jié)

程序員是一個(gè)特別依賴個(gè)人技術(shù)能力的職業(yè),不同的程序員之間,技術(shù)能力的差別也非常大,不斷地深挖技術(shù),補(bǔ)充自己的知識(shí)體系,是一個(gè)技術(shù)人成長的必要條件之一

JOIN運(yùn)算確實(shí)是數(shù)據(jù)庫中最復(fù)雜的運(yùn)算,本文對JOIN運(yùn)算進(jìn)行了深入的剖析整理,篇幅已經(jīng)不小,但仍然也沒有完全窮盡所有方面。

SPL資料

SPL官網(wǎng)

SPL下載

SPL源代碼

到此這篇關(guān)于體系化探討令人頭疼的JOIN運(yùn)算的文章就介紹到這了,更多相關(guān)JOIN運(yùn)算內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL刪除表數(shù)據(jù)的方法

    MySQL刪除表數(shù)據(jù)的方法

    這篇文章主要介紹了MySQL刪除表數(shù)據(jù)的方法,小編覺得還是挺不錯(cuò)的,這里給大家分享一下,需要的朋友可以參考。
    2017-10-10
  • mysql 8.0.17 解壓版安裝配置方法圖文教程

    mysql 8.0.17 解壓版安裝配置方法圖文教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.17 解壓版安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • Mysql添加用戶和設(shè)置權(quán)限的操作方法

    Mysql添加用戶和設(shè)置權(quán)限的操作方法

    這篇文章主要介紹了Mysql添加用戶和設(shè)置權(quán)限的操作方法,主要包括管理用戶,權(quán)限控制的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解

    mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解

    今天小編就為大家分享一篇關(guān)于mysql事務(wù)select for update及數(shù)據(jù)的一致性處理講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • 詳解MySQL數(shù)據(jù)庫優(yōu)化的八種方式(經(jīng)典必看)

    詳解MySQL數(shù)據(jù)庫優(yōu)化的八種方式(經(jīng)典必看)

    關(guān)于數(shù)據(jù)庫優(yōu)化,網(wǎng)上有不少資料和方法,但是不少質(zhì)量參差不齊,有些總結(jié)的不夠到位,內(nèi)容冗雜。今天給大家分享一篇文章關(guān)于mysql數(shù)據(jù)庫優(yōu)化的八種方式,非常經(jīng)典,需要的的朋友參考下
    2017-03-03
  • MySQL表的重命名字段添加及字段屬性修改操作語法

    MySQL表的重命名字段添加及字段屬性修改操作語法

    這篇文章主要為大家介紹了MySQL表的重命名字段添加及字段屬性修改語法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • mysql三種批量增加的性能分析

    mysql三種批量增加的性能分析

    最近在深入學(xué)習(xí)hibernate,在進(jìn)行批量操作時(shí),發(fā)現(xiàn)hibernate批量操作性能非常低.于是就想找一個(gè)性能較高的方法,在對jdbc、jdbcTemplate、hibernate進(jìn)行測試后,發(fā)現(xiàn)jdbc的執(zhí)行效率是最高的,jdbcTemplate也很相近,hibernate就不考慮了,慘不忍睹啊
    2012-08-08
  • mysql插入前判斷數(shù)據(jù)是否存在的操作

    mysql插入前判斷數(shù)據(jù)是否存在的操作

    這篇文章主要介紹了mysql插入前判斷數(shù)據(jù)是否存在的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Mysql CONVERT函數(shù)的具體使用

    Mysql CONVERT函數(shù)的具體使用

    本文主要介紹了Mysql CONVERT函數(shù)的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • MySQL中的datediff()方法和timestampdiff()方法的應(yīng)用示例小結(jié)

    MySQL中的datediff()方法和timestampdiff()方法的應(yīng)用示例小結(jié)

    在MySQL中,DATEDIFF()函數(shù)和TIMESTAMPDIFF()函數(shù)用于計(jì)算日期和時(shí)間之間的差異,TIMESTAMPDIFF()函數(shù)返回的結(jié)果是整數(shù),但你可以通過在計(jì)算過程中使用適當(dāng)?shù)某▉慝@得所需的小數(shù)部分,本文介紹MySQL中的datediff()方法和timestampdiff()方法的應(yīng)用,感興趣的朋友一起看看吧
    2023-12-12

最新評(píng)論

不卡一区一区三区在线| 亚洲va国产va欧美精品88| 日本一道二三区视频久久| 天堂av在线最新版在线| 亚洲av香蕉一区区二区三区犇| 国产综合视频在线看片| 蝴蝶伊人久久中文娱乐网| 99精品视频在线观看婷婷| 天堂女人av一区二区| 人妻少妇一区二区三区蜜桃| 亚洲欧美国产综合777| 久久免看30视频口爆视频| 国产又色又刺激在线视频| 五色婷婷综合狠狠爱| h国产小视频福利在线观看| 亚洲一区二区三区av网站| 国产精品大陆在线2019不卡| 亚洲精品ww久久久久久| 久久www免费人成一看片| 在线观看一区二区三级| 经典亚洲伊人第一页| 亚洲av天堂在线播放| 18禁网站一区二区三区四区| 操操网操操伊剧情片中文字幕网| caoporm超碰国产| 欧美成人精品欧美一级黄色| 色综合色综合色综合色| 日本后入视频在线观看| 精品一区二区三区在线观看| 97超碰人人搞人人| 2022国产综合在线干| www日韩a级s片av| 91www一区二区三区| 国产精品一区二区av国| 超污视频在线观看污污污| 中文字幕在线第一页成人| 免费人成黄页网站在线观看国产| 人妻3p真实偷拍一二区| 日本人竟这样玩学生妹| 97色视频在线观看| 91久久综合男人天堂| 久久久久久久久久一区二区三区| 天天躁夜夜躁日日躁a麻豆| 亚洲 中文 自拍 无码| 精品av国产一区二区三区四区| 99re国产在线精品| 免费看国产又粗又猛又爽又黄视频| 天天操天天干天天艹| 极品粉嫩小泬白浆20p主播 | 欧美成人一二三在线网| 中英文字幕av一区| 亚洲中文字幕校园春色| 亚洲av在线观看尤物| 久久这里有免费精品| 日本一道二三区视频久久 | 一区国内二区日韩三区欧美| 五十路丰满人妻熟妇| 中文字幕一区的人妻欧美日韩| 3337p日本欧洲大胆色噜噜| 40道精品招牌菜特色| 丝袜美腿视频诱惑亚洲无| 美女骚逼日出水来了| 国产一区二区视频观看| 天天操天天干天天日狠狠插| 在线视频国产欧美日韩| 日韩激情文学在线视频| 欧美精品国产综合久久| av男人天堂狠狠干| 75国产综合在线视频| 91人妻精品久久久久久久网站| 午夜精品福利一区二区三区p| 国产精品国产三级国产精东| 超pen在线观看视频公开97| 国产免费av一区二区凹凸四季| 久久久久久久精品成人热| 97色视频在线观看| 天天射夜夜操狠狠干| 天天操天天污天天射| 日韩av中文在线免费观看| 97精品视频在线观看| 自拍偷区二区三区麻豆| 人妻丰满熟妇综合网| 国产一区二区久久久裸臀| 操的小逼流水的文章| lutube在线成人免费看| 午夜福利人人妻人人澡人人爽| 狠狠躁夜夜躁人人爽天天天天97| 天天摸天天亲天天舔天天操天天爽| 久久热这里这里只有精品| 日韩熟女av天堂系列| 成人影片高清在线观看| 女同性ⅹxx女同hd| 亚洲一区二区三区精品乱码| 日本av在线一区二区三区| 女同久久精品秋霞网| 99热这里只有国产精品6| 大黑人性xxxxbbbb| 日本熟女50视频免费| 可以免费看的www视频你懂的| 91九色porny蝌蚪国产成人| 动漫精品视频在线观看| 天天艹天天干天天操| 蜜臀av久久久久久久| 欧美一区二区三区啪啪同性| 99人妻视频免费在线| 天天做天天干天天操天天射| 国产视频网站一区二区三区| 天堂中文字幕翔田av| 亚洲欧美人精品高清| 久久久久久久久久一区二区三区 | 成人av在线资源网站| 91人妻人人做人人爽在线| 国产精品人妻66p| 视频啪啪啪免费观看| 黄页网视频在线免费观看| 欧美色呦呦最新网址| 亚洲美女自偷自拍11页| 午夜在线观看岛国av,com| 日本最新一二三区不卡在线| 黄色录像鸡巴插进去| 国产黄色a级三级三级三级| 大肉大捧一进一出好爽在线视频| 日本最新一二三区不卡在线 | 欧美另类一区二区视频| 夜夜骑夜夜操夜夜奸| 日本少妇的秘密免费视频| 视频一区 二区 三区 综合| 美女少妇亚洲精选av| 欧美日韩在线精品一区二区三| 综合精品久久久久97| 91精品国产观看免费| 欧美日韩一级黄片免费观看| 亚洲av日韩av第一区二区三区| 91九色国产porny蝌蚪| 五月激情婷婷久久综合网| 亚洲av一妻不如妾| 这里只有精品双飞在线播放| 操日韩美女视频在线免费看| 女生自摸在线观看一区二区三区 | 精品老妇女久久9g国产| 精品亚洲在线免费观看| 亚洲一级特黄特黄黄色录像片| 国产免费av一区二区凹凸四季| 视频久久久久久久人妻| 国产精品久久久久久久精品视频| 亚洲1卡2卡三卡4卡在线观看| 久碰精品少妇中文字幕av | 最新日韩av传媒在线| 国产使劲操在线播放| 美女福利写真在线观看视频| a v欧美一区=区三区| 欧美怡红院视频在线观看| 亚洲人妻30pwc| 国产女人被做到高潮免费视频| 最新国产亚洲精品中文在线| 爱有来生高清在线中文字幕| 久久久制服丝袜中文字幕| 中文字幕在线第一页成人| 久久久制服丝袜中文字幕| yy96视频在线观看| 午夜美女少妇福利视频| 国产九色91在线视频| 国产中文字幕四区在线观看| 天天做天天爽夜夜做少妇| 中文字幕综合一区二区| 国产普通话插插视频| 天堂av在线播放免费| 婷婷色中文亚洲网68| 欧美麻豆av在线播放| 人人妻人人澡人人爽人人dvl| 久久尻中国美女视频| 91精品一区二区三区站长推荐| 91中文字幕免费在线观看| 蜜桃视频17c在线一区二区| 国产V亚洲V天堂无码欠欠 | 亚洲天天干 夜夜操| 93精品视频在线观看| 18禁污污污app下载| 婷婷久久一区二区字幕网址你懂得| japanese五十路熟女熟妇| 55夜色66夜色国产精品站| 日本少妇人妻xxxxx18| 538精品在线观看视频| 日本美女性生活一级片| chinese国产盗摄一区二区| 人人妻人人爽人人澡人人精品| 91精品国产综合久久久蜜| 国产视频网站国产视频| 国产精品视频资源在线播放| 日韩av有码一区二区三区4| 3344免费偷拍视频| 午夜极品美女福利视频| 三上悠亚和黑人665番号| 在线观看视频污一区| av在线资源中文字幕| 国产黄色a级三级三级三级| 丰满少妇人妻xxxxx| 偷拍自拍国产在线视频| 国产黄色大片在线免费播放| 青草亚洲视频在线观看| 国产在线观看黄色视频| 中文字幕1卡1区2区3区| 又黄又刺激的午夜小视频| 丰满的继坶3中文在线观看| 欧美亚洲免费视频观看| 91亚洲手机在线视频播放| 国产久久久精品毛片| 色在线观看视频免费的| 91香蕉成人app下载| 国产成人精品av网站| 伊人情人综合成人久久网小说| 欧美一级片免费在线成人观看| 亚洲一区二区三区av网站| 人妻久久久精品69系列| 女同久久精品秋霞网| 韩国一级特黄大片做受| 2019av在线视频| 第一福利视频在线观看| 熟女少妇激情五十路| 99热久久这里只有精品| 自拍偷拍 国产资源| 97成人免费在线观看网站| 欧美美女人体视频一区| 香蕉91一区二区三区| 亚洲av日韩精品久久久久久hd| 大肉大捧一进一出好爽在线视频| brazzers欧熟精品系列| 免费在线观看污污视频网站| 激情色图一区二区三区| 老有所依在线观看完整版| 久久精品国产23696| 久草视频福利在线首页| 自拍偷拍 国产资源| 国产日本欧美亚洲精品视| 适合午夜一个人看的视频| 白嫩白嫩美女极品国产在线观看| 成人av中文字幕一区| 天堂中文字幕翔田av| 天天日天天添天天爽| 在线观看亚洲人成免费网址| 十八禁在线观看地址免费| 国产黄色高清资源在线免费观看| 亚洲精品国产在线电影| 国产熟妇一区二区三区av| 超pen在线观看视频公开97 | 综合精品久久久久97| 亚洲熟女综合色一区二区三区四区| 1区2区3区不卡视频| 天天操天天污天天射| 亚洲精品午夜aaa久久| 大胆亚洲av日韩av| 婷婷色国产黑丝少妇勾搭AV | 免费av岛国天堂网站| 精品久久久久久久久久久99| 免费高清自慰一区二区三区网站| 人妻熟女在线一区二区| 人妻久久无码中文成人| 国产乱子伦一二三区| 国产伦精品一区二区三区竹菊| 成人高清在线观看视频| 亚洲天堂有码中文字幕视频| 护士小嫩嫩又紧又爽20p| 国内资源最丰富的网站| 蜜桃久久久久久久人妻| 国产视频一区二区午夜| 午夜成午夜成年片在线观看| 2o22av在线视频| 亚洲av天堂在线播放| 国产麻豆乱子伦午夜视频观看| 社区自拍揄拍尻屁你懂的| 亚洲卡1卡2卡三卡四老狼| 日本av在线一区二区三区| av天堂中文字幕最新| 边摸边做超爽毛片18禁色戒 | 日本午夜爽爽爽爽爽视频在线观看| 亚洲Av无码国产综合色区| 欧美视频不卡一区四区| 精品成人啪啪18免费蜜臀| 99精品国产免费久久| 国产成人自拍视频在线免费观看| 四虎永久在线精品免费区二区| 久久久久久性虐视频| 欧美另类一区二区视频| 日本福利午夜电影在线观看| 老鸭窝在线观看一区| 精品老妇女久久9g国产| 日本乱人一区二区三区| 日韩精品一区二区三区在线播放 | 亚洲 清纯 国产com| 国产成人综合一区2区| 亚洲一区自拍高清免费视频| 成人资源在线观看免费官网| 粉嫩欧美美人妻小视频| 青青草原网站在线观看| 狠狠地躁夜夜躁日日躁| av线天堂在线观看| 欧美va不卡视频在线观看| 99热久久极品热亚洲| 欧美美女人体视频一区| 晚上一个人看操B片| 午夜dv内射一区区| 男女啪啪啪啪啪的网站| 99av国产精品欲麻豆| 老司机你懂得福利视频| 午夜国产福利在线观看| 青青草亚洲国产精品视频| 日韩在线视频观看有码在线| 亚洲一级av大片免费观看| 青青擦在线视频国产在线| av天堂中文字幕最新| 国产中文精品在线观看| 亚洲精品色在线观看视频| 亚洲欧美成人综合视频| 色婷婷精品大在线观看| 精品一区二区三区午夜| 亚洲国产成人无码麻豆艾秋| 亚洲黄色av网站免费播放| 久久久人妻一区二区| 特大黑人巨大xxxx| 国产精品福利小视频a| 欧美成人精品在线观看| 成人av电影免费版| 欧美久久久久久三级网| 亚洲精品乱码久久久久久密桃明 | 亚洲美女美妇久久字幕组| 性欧美激情久久久久久久| 黄色大片男人操女人逼| 亚洲av人人澡人人爽人人爱| 偷拍自拍国产在线视频| 任你操视频免费在线观看| 91快播视频在线观看| 亚洲的电影一区二区三区| 最新国产精品拍在线观看| 91人妻精品一区二区在线看| 中文字幕国产专区欧美激情| 亚洲中文字幕人妻一区| 在线视频这里只有精品自拍| 好男人视频在线免费观看网站| 青青青国产片免费观看视频| 播放日本一区二区三区电影| 换爱交换乱高清大片| 天天色天天舔天天射天天爽| 欧美精产国品一二三区| 无码日韩人妻精品久久| 青青青青爽手机在线| 欧美日韩国产一区二区三区三州| 在线观看免费岛国av| 青青青视频自偷自拍38碰| 2021年国产精品自拍| 国产精品探花熟女在线观看| 亚洲综合一区二区精品久久| 无套猛戳丰满少妇人妻| av老司机亚洲一区二区| 99热久久这里只有精品8| 91桃色成人网络在线观看| 最新激情中文字幕视频| 888欧美视频在线| 骚货自慰被发现爆操| 一区二区免费高清黄色视频| av中文字幕电影在线看| 色av色婷婷人妻久久久精品高清| 自拍偷拍日韩欧美一区二区| 五月天久久激情视频| 国产老熟女伦老熟妇ⅹ| 天天日夜夜干天天操| 端庄人妻堕落挣扎沉沦| 天堂av中文在线最新版| 九色精品视频在线播放| 日本av高清免费网站| japanese日本熟妇另类| 五色婷婷综合狠狠爱| 青青青青草手机在线视频免费看| 中文字幕之无码色多多| 日本少妇高清视频xxxxx| 久久久久久国产精品| 国产精品国产三级国产午| 美女大bxxxx内射| 色天天天天射天天舔| 91免费观看在线网站| 视频一区二区三区高清在线| 国产亚洲视频在线观看| 一级黄色av在线观看| 91av精品视频在线| 国产精品日韩欧美一区二区| 日本一本午夜在线播放| 久久综合老鸭窝色综合久久| av天堂加勒比在线| 操操网操操伊剧情片中文字幕网| 2022天天干天天操| 全国亚洲男人的天堂| 免费高清自慰一区二区三区网站| 天天摸天天日天天操| 一区二区三区欧美日韩高清播放| 38av一区二区三区| 日本高清撒尿pissing| 91片黄在线观看喷潮| 欧美日韩一区二区电影在线观看| 亚洲另类综合一区小说| 男生用鸡操女生视频动漫| 被大鸡吧操的好舒服视频免费| 国产美女一区在线观看| 日辽宁老肥女在线观看视频| 日本韩国亚洲综合日韩欧美国产| 免费男阳茎伸入女阳道视频| 福利在线视频网址导航| 一区二区三区麻豆福利视频| 国产午夜福利av导航| 999久久久久999| 日本熟妇喷水xxx| 天堂中文字幕翔田av| 999久久久久999| 国产熟妇乱妇熟色T区| 伊人日日日草夜夜草| 首之国产AV医生和护士小芳| 国内资源最丰富的网站| 中文字幕日韩精品日本| 唐人色亚洲av嫩草| 888亚洲欧美国产va在线播放| 黄网十四区丁香社区激情五月天| 天天日天天爽天天干| 3337p日本欧洲大胆色噜噜| 2021久久免费视频| 精品高跟鞋丝袜一区二区| 99精品免费久久久久久久久a| 亚洲熟色妇av日韩熟色妇在线| 91 亚洲视频在线观看| 女同久久精品秋霞网| 福利视频广场一区二区| 男大肉棒猛烈插女免费视频| 99av国产精品欲麻豆| 看一级特黄a大片日本片黑人| 精品一区二区亚洲欧美| 久久久精品精品视频视频| 日韩午夜福利精品试看| 亚洲精品久久视频婷婷| 久久艹在线观看视频| 日本人妻欲求不满中文字幕| 日本熟女精品一区二区三区| 精品国产污污免费网站入口自| 欧美在线偷拍视频免费看| 少妇露脸深喉口爆吞精| 人人爽亚洲av人人爽av| 亚洲精品ww久久久久久| 无忧传媒在线观看视频| 三级等保密码要求条款| 亚洲av无女神免非久久| 国产综合高清在线观看| 自拍偷拍一区二区三区图片| 一区二区三区国产精选在线播放| 青青青爽视频在线播放| 黑人3p华裔熟女普通话| 亚洲精品乱码久久久本| 中文字幕国产专区欧美激情| 天堂女人av一区二区| 精品91自产拍在线观看一区| 日韩亚洲高清在线观看| 精品一区二区三区三区88| 国产又粗又硬又猛的毛片视频| 97瑟瑟超碰在线香蕉| 男女第一次视频在线观看| 国产97视频在线精品| 亚洲熟妇x久久av久久| 狠狠地躁夜夜躁日日躁| 婷婷久久久综合中文字幕| 青青色国产视频在线| 大学生A级毛片免费视频| 天天操天天干天天艹| 18禁美女羞羞免费网站| 欧美精品资源在线观看| 无码日韩人妻精品久久| 97超碰免费在线视频| 精品视频中文字幕在线播放| 国产精品一区二区av国| 欧美日韩一区二区电影在线观看| 91亚洲精品干熟女蜜桃频道| 亚洲区欧美区另类最新章节| 亚洲另类综合一区小说| 日本美女成人在线视频| 青青草国内在线视频精选| 午夜大尺度无码福利视频| 天天操天天干天天日狠狠插| 国产精品视频男人的天堂| 亚洲精品av在线观看| 免费69视频在线看| 大鸡吧插逼逼视频免费看 | 黄色片年轻人在线观看| 亚洲精品国品乱码久久久久| 国产欧美日韩第三页| 国产精彩福利精品视频| 毛片一级完整版免费| 亚洲精品国产久久久久久| 一区二区三区综合视频| 婷婷色国产黑丝少妇勾搭AV| 亚洲天堂av最新网址| av手机在线免费观看日韩av| 亚洲第17页国产精品| 插逼视频双插洞国产操逼插洞| 激情伦理欧美日韩中文字幕| 亚洲精品国品乱码久久久久| 性生活第二下硬不起来| 亚洲欧美综合另类13p| 精品一区二区三区三区色爱| 97年大学生大白天操逼| 男生舔女生逼逼视频| 日本韩国在线观看一区二区| 成年人的在线免费视频| 精品乱子伦一区二区三区免费播| 性生活第二下硬不起来| aⅴ五十路av熟女中出| 男大肉棒猛烈插女免费视频| 91色网站免费在线观看| 性色av一区二区三区久久久| 偷拍自拍福利视频在线观看| 中文字幕一区二区人妻电影冢本 | 11久久久久久久久久久| 色吉吉影音天天干天天操| 色婷婷综合激情五月免费观看| 国产chinesehd精品麻豆| 2022精品久久久久久中文字幕| 国产又粗又硬又猛的毛片视频| 免费av岛国天堂网站| 久久久久久久亚洲午夜综合福利| 91欧美在线免费观看| 中文字幕在线第一页成人| 日本xx片在线观看| 国产欧美日韩第三页| 日日夜夜狠狠干视频| 在线播放 日韩 av| 偷青青国产精品青青在线观看| 大香蕉玖玖一区2区| 婷婷激情四射在线观看视频| 久久久久久性虐视频| 亚洲变态另类色图天堂网| 欧美日韩不卡一区不区二区| 精品人妻伦一二三区久| 日韩av大胆在线观看| 五十路熟女人妻一区二区9933 | 宅男噜噜噜666国产| 三上悠亚和黑人665番号| 又粗又硬又猛又黄免费30| 爆乳骚货内射骚货内射在线| 天堂av在线官网中文| 动漫黑丝美女的鸡巴| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲蜜臀av一区二区三区九色| 绝色少妇高潮3在线观看| 天天干天天操天天玩天天射| 亚洲午夜福利中文乱码字幕| 夜夜嗨av蜜臀av| 亚洲av极品精品在线观看| 亚洲av成人免费网站| 中文字幕熟女人妻久久久| 国产老熟女伦老熟妇ⅹ| 中文字幕,亚洲人妻| 免费在线福利小视频| 中文字幕,亚洲人妻| 93精品视频在线观看| 91欧美在线免费观看| 黄片大全在线观看观看| 精品国产成人亚洲午夜| 端庄人妻堕落挣扎沉沦| 家庭女教师中文字幕在线播放| 欧美一级片免费在线成人观看| 免费看国产av网站| 自拍偷拍亚洲精品第2页| 中文字幕免费在线免费| gav成人免费播放| 晚上一个人看操B片| 老司机免费视频网站在线看| 爱有来生高清在线中文字幕| 日本少妇的秘密免费视频| 欧美亚洲免费视频观看| 中文字幕+中文字幕| 免费看国产av网站| 国产女人被做到高潮免费视频| 亚洲综合色在线免费观看| 岛国黄色大片在线观看| 国产精品日韩欧美一区二区| 国产精品大陆在线2019不卡| 偷青青国产精品青青在线观看| 亚洲特黄aaaa片| 欧美精品一区二区三区xxxx| 免费大片在线观看视频网站| 天天日天天干天天搡| 成年人免费看在线视频| 欧美中文字幕一区最新网址| 成人午夜电影在线观看 久久| 久草极品美女视频在线观看| yellow在线播放av啊啊啊| 亚洲av日韩精品久久久| 成人网18免费视频版国产| 91精品啪在线免费| 午夜美女福利小视频| 一区二区三区在线视频福利| 真实国产乱子伦一区二区| 国产精品黄色的av| 中文字幕日韩91人妻在线| 天天干天天操天天爽天天摸| 亚洲欧美清纯唯美另类| 天天日天天添天天爽| 亚洲中文字幕人妻一区| 视频 一区二区在线观看| 青青草视频手机免费在线观看| 婷婷色中文亚洲网68| 可以免费看的www视频你懂的| 欧美特级特黄a大片免费| 中文字幕第三十八页久久| 国产精品伦理片一区二区| 亚洲福利精品福利精品福利| 日日爽天天干夜夜操| 2o22av在线视频| 一区二区三区在线视频福利| 午夜精品久久久久麻豆影视| av完全免费在线观看av| 最新黄色av网站在线观看| yellow在线播放av啊啊啊| 成人午夜电影在线观看 久久| 最新黄色av网站在线观看| 精品人人人妻人人玩日产欧| 中文字幕第三十八页久久| 欧美区一区二区三视频| 女同久久精品秋霞网| 女人精品内射国产99| 中文字幕第三十八页久久| 国产免费高清视频视频| 亚洲中文字幕乱码区| 国产成人无码精品久久久电影| 在线成人日韩av电影| 黑人3p华裔熟女普通话| 国产激情av网站在线观看| 中文字幕在线免费第一页| 99热碰碰热精品a中文| 五十路av熟女松本翔子| 中文字幕免费福利视频6| 人妻3p真实偷拍一二区| 亚洲综合在线观看免费| 久久久制服丝袜中文字幕| yy6080国产在线视频| 男人的天堂在线黄色| 中文字幕在线乱码一区二区| 日本一区美女福利视频| 开心 色 六月 婷婷| 97精品人妻一区二区三区精品| 国产真实灌醉下药美女av福利| 激情小视频国产在线| 91麻豆精品秘密入口在线观看| 香港一级特黄大片在线播放| 黑人乱偷人妻中文字幕| 91精品高清一区二区三区| 91快播视频在线观看| 亚洲人成精品久久久久久久| 免费大片在线观看视频网站| 久久这里只有精品热视频 | 中文字幕在线视频一区二区三区 | 青青擦在线视频国产在线| 99精品视频之69精品视频 | 老鸭窝日韩精品视频观看| 亚洲精品 欧美日韩| 91香蕉成人app下载| 性欧美日本大妈母与子| 2012中文字幕在线高清| 91在线免费观看成人| 女蜜桃臀紧身瑜伽裤| 91麻豆精品久久久久| 亚洲免费福利一区二区三区| 黑人3p华裔熟女普通话| 国产日韩精品电影7777| 亚洲第一黄色在线观看| 中文字幕日韩精品就在这里| 最近中文字幕国产在线| 亚洲 国产 成人 在线| 欧美日本国产自视大全| 中文字幕,亚洲人妻| 99久久中文字幕一本人| 专门看国产熟妇的网站| 在线新三级黄伊人网| 中文字幕中文字幕人妻| 亚洲成人激情av在线| 97精品成人一区二区三区| 狠狠躁夜夜躁人人爽天天久天啪| huangse网站在线观看| 亚洲1069综合男同| 中文字幕日韩人妻在线三区| 视频在线免费观看你懂得| 91久久精品色伊人6882| 亚洲高清一区二区三区视频在线| 啪啪啪操人视频在线播放| 欧美性受xx黑人性猛交| 亚洲天堂av最新网址| lutube在线成人免费看| 天堂av在线播放免费| 亚洲中文字字幕乱码| 婷婷色中文亚洲网68| huangse网站在线观看| 欧美精产国品一二三产品价格| 黄色视频成年人免费观看| 天天日天天敢天天干| 中文字幕乱码av资源| 亚洲在线一区二区欧美| 啊用力插好舒服视频| 91p0rny九色露脸熟女| 啊啊啊视频试看人妻| 亚洲综合在线视频可播放| 国产精彩福利精品视频| 人人人妻人人澡人人| 欧美亚洲少妇福利视频| 精品视频一区二区三区四区五区| 精品国产亚洲av一淫| 激情国产小视频在线| 亚洲高清视频在线不卡| 一区二区三区四区五区性感视频 | 亚洲午夜福利中文乱码字幕| 午夜在线观看一区视频| 18禁美女黄网站色大片下载| 国产中文字幕四区在线观看| 成年人中文字幕在线观看| 天天躁日日躁狠狠躁av麻豆| 国产片免费观看在线观看| 午夜精品久久久久久99热| 哥哥姐姐综合激情小说| 国产亚洲天堂天天一区| 人妻久久久精品69系列| 日韩欧美国产精品91| 狍和女人的王色毛片| 亚洲黄色av网站免费播放| 国产又粗又硬又大视频| 国产va在线观看精品| 国产成人综合一区2区| 亚洲午夜伦理视频在线| 蜜桃视频入口久久久| 夜夜嗨av蜜臀av| 好了av中文字幕在线| 91香蕉成人app下载| 曰本无码人妻丰满熟妇啪啪| 日韩特级黄片高清在线看| 在线新三级黄伊人网| 午夜91一区二区三区| 国产成人午夜精品福利| okirakuhuhu在线观看| 2019av在线视频| 国产午夜无码福利在线看| 天天干天天操天天玩天天射| 色婷婷精品大在线观看| 精品成人啪啪18免费蜜臀| 欲满人妻中文字幕在线| 日韩精品激情在线观看| 2o22av在线视频| 国产美女午夜福利久久| 超碰在线观看免费在线观看| 欧美日韩国产一区二区三区三州| 国产欧美日韩第三页| 青青青青青青草国产| 人人妻人人爱人人草| 日本免费一级黄色录像| 亚洲老熟妇日本老妇| 美日韩在线视频免费看| av中文字幕福利网| 老鸭窝在线观看一区| 国产在线观看黄色视频| 亚洲国产精品久久久久久6| 超碰在线中文字幕一区二区| 欧美激情电影免费在线| 午夜久久久久久久99| 久久一区二区三区人妻欧美| 日韩精品二区一区久久| 亚洲超碰97人人做人人爱| 日本免费午夜视频网站| 大香蕉伊人中文字幕| 又色又爽又黄又刺激av网站| 午夜激情精品福利视频| 男人的天堂av日韩亚洲| 91国内精品久久久久精品一| 午夜精品九一唐人麻豆嫩草成人| 欧美精产国品一二三产品价格| 狠狠鲁狠狠操天天晚上干干| 可以免费看的www视频你懂的| 免费手机黄页网址大全| 日本少妇精品免费视频| 中文字幕午夜免费福利视频| 国内资源最丰富的网站| 九色porny九色9l自拍视频| 一区二区视频在线观看视频在线| 中文字日产幕乱六区蜜桃| 日本成人不卡一区二区| 欲满人妻中文字幕在线| 亚洲 欧美 精品 激情 偷拍| 亚洲激情,偷拍视频| 欧美美女人体视频一区| 99av国产精品欲麻豆| 护士小嫩嫩又紧又爽20p| 在线观看日韩激情视频| 国产黄色a级三级三级三级| 日本人妻少妇18—xx| 亚洲免费av在线视频| 大白屁股精品视频国产| 一色桃子久久精品亚洲| 无码中文字幕波多野不卡| 人妻少妇亚洲精品中文字幕| 91老师蜜桃臀大屁股| 日韩精品一区二区三区在线播放| 大陆av手机在线观看| 欧美黑人性暴力猛交喷水| 亚洲欧美一卡二卡三卡| 欧美天堂av无线av欧美| 日曰摸日日碰夜夜爽歪歪| 日本人妻少妇18—xx| 最新97国产在线视频| 又粗又硬又猛又爽又黄的| 懂色av蜜桃a v| 亚洲成人国产av在线| 欧美日韩精品永久免费网址| 亚洲av一妻不如妾| 国产又大又黄免费观看| 亚洲公开视频在线观看| 国产亚洲欧美另类在线观看| 日韩一区二区三区三州| 97人妻色免费视频| 超碰公开大香蕉97| 亚洲熟女久久久36d| weyvv5国产成人精品的视频| 91国产资源在线视频| chinese国产盗摄一区二区 | 成人av在线资源网站| 国产黄色大片在线免费播放| 亚洲欧洲一区二区在线观看| 日本一二三区不卡无| 国产精品精品精品999| 免费国产性生活视频| 黄色的网站在线免费看 | 亚洲精品精品国产综合| 日美女屁股黄邑视频| 自拍偷拍亚洲欧美在线视频| 亚洲男人在线天堂网| 人妻凌辱欧美丰满熟妇| 亚洲 国产 成人 在线| 亚洲视频在线观看高清| 国产亚洲四十路五十路| 中文字幕+中文字幕| mm131美女午夜爽爽爽| 亚洲狠狠婷婷综合久久app| chinese国产盗摄一区二区| 又色又爽又黄的美女裸体| 亚洲va天堂va国产va久| 日本av熟女在线视频| 九九热99视频在线观看97| 日曰摸日日碰夜夜爽歪歪| 欧美80老妇人性视频| 久碰精品少妇中文字幕av| 日曰摸日日碰夜夜爽歪歪| 欧美视频中文一区二区三区| 一级黄色片夫妻性生活| av在线播放国产不卡| 狠狠躁夜夜躁人人爽天天天天97| 亚洲国产40页第21页| 亚洲天天干 夜夜操| 黑人乱偷人妻中文字幕| 91九色国产porny蝌蚪| 天天爽夜夜爽人人爽QC| 人妻爱爱 中文字幕| 在线免费观看欧美小视频| 午夜极品美女福利视频| 久久久久久久久久一区二区三区| 日本av高清免费网站| 大鸡吧插入女阴道黄色片| 亚洲高清国产拍青青草原| 国产综合视频在线看片| 色综合久久五月色婷婷综合| 亚洲狠狠婷婷综合久久app| 果冻传媒av一区二区三区| 少妇ww搡性bbb91| 日日摸夜夜添夜夜添毛片性色av| 天天操,天天干,天天射| a v欧美一区=区三区| 日韩北条麻妃一区在线| 国产精品国产三级国产午| 亚洲成人三级在线播放| 在线观看911精品国产| 经典国语激情内射视频| 国产无遮挡裸体免费直播视频| 精品国产亚洲av一淫| 亚洲熟妇x久久av久久| 亚洲激情,偷拍视频| 98视频精品在线观看| 99精品国产自在现线观看| 日本啪啪啪啪啪啪啪| 免费观看丰满少妇做受| 青娱乐在线免费视频盛宴| 大鸡吧插逼逼视频免费看| 日韩人妻在线视频免费| 人妻丝袜榨强中文字幕| 国产九色91在线观看精品| 亚洲欧美成人综合视频| 岛国青草视频在线观看| 91精品激情五月婷婷在线| 免费看美女脱光衣服的视频| 成年人午夜黄片视频资源| www日韩a级s片av| 国产亚洲成人免费在线观看| 国产又粗又硬又猛的毛片视频| 亚洲中文字幕校园春色| 久久久久五月天丁香社区| 亚洲一级av无码一级久久精品| 亚洲护士一区二区三区| 夜夜嗨av蜜臀av| 97香蕉碰碰人妻国产樱花| 亚洲少妇人妻无码精品| 国产精品国产三级国产午| 欧美香蕉人妻精品一区二区| 亚洲欧美成人综合在线观看| 特大黑人巨大xxxx| 黄色片黄色片wyaa| 综合一区二区三区蜜臀| 91免费福利网91麻豆国产精品| 精品国产亚洲av一淫| 国产精品国产精品一区二区| 亚洲av极品精品在线观看| 又粗又长 明星操逼小视频| 亚洲国产精品久久久久蜜桃| 国产成人精品一区在线观看| 午夜精品九一唐人麻豆嫩草成人| 亚洲成高清a人片在线观看| 亚洲成人激情av在线| 后入美女人妻高清在线| 日日夜夜大香蕉伊人| 97香蕉碰碰人妻国产樱花| 2018最新中文字幕在线观看| 大鸡巴操b视频在线| 人妻少妇精品久久久久久| 天天躁日日躁狠狠躁躁欧美av | 国产污污污污网站在线| 免费看高清av的网站| 亚洲欧美精品综合图片小说| 91福利视频免费在线观看| 91自产国产精品视频| 欧美熟妇一区二区三区仙踪林| av网址国产在线观看| 老司机你懂得福利视频| 一区二区熟女人妻视频| 久久久久国产成人精品亚洲午夜| 男人和女人激情视频| 91老师蜜桃臀大屁股| 欧美区一区二区三视频| 欧美精品久久久久久影院| 精品少妇一二三视频在线| 91久久综合男人天堂| 91超碰青青中文字幕| 亚洲av男人的天堂你懂的| 美女福利视频导航网站| 国产精品福利小视频a| 久久久久久国产精品| 亚洲一区二区三区久久受| 9l人妻人人爽人人爽| 欧美在线偷拍视频免费看| 日本在线一区二区不卡视频| 毛片av在线免费看| 亚洲av一妻不如妾| 亚洲欧美国产麻豆综合| 91老熟女连续高潮对白| 精品美女福利在线观看| 一区二区三区 自拍偷拍| 2022国产综合在线干| 人人妻人人人操人人人爽| av中文字幕在线导航| 熟女妇女老妇一二三区| 五十路熟女人妻一区二区9933| 熟女少妇激情五十路| 欧美视频不卡一区四区| 91自产国产精品视频| 中文字幕一区二区亚洲一区| 午夜蜜桃一区二区三区| 久青青草视频手机在线免费观看| 日本裸体熟妇区二区欧美| 午夜毛片不卡免费观看视频| 经典国语激情内射视频| 国产福利在线视频一区| 天堂av在线官网中文| 日韩一区二区三区三州| 女生被男生插的视频网站| heyzo蜜桃熟女人妻| 97人人妻人人澡人人爽人人精品| 国产黄色片蝌蚪九色91| 久久久久久久亚洲午夜综合福利| 国产日韩精品免费在线| 中文字幕免费福利视频6| 一区二区三区精品日本| 美女吃鸡巴操逼高潮视频| 天天色天天爱天天爽| 成人久久精品一区二区三区| 日韩剧情片电影在线收看| 欧美一区二区三区啪啪同性| 亚洲精品三级av在线免费观看| 男人天堂av天天操| 日韩欧美国产一区不卡| 天天操天天污天天射| 99热色原网这里只有精品| 大鸡吧插入女阴道黄色片| 69精品视频一区二区在线观看| av天堂中文字幕最新| 亚洲公开视频在线观看| 97人妻夜夜爽二区欧美极品| 97精品综合久久在线| 国产超码片内射在线| 久久精品亚洲国产av香蕉| 黄工厂精品视频在线观看| 国产污污污污网站在线| 欧美日韩中文字幕欧美| 国产免费高清视频视频| 影音先锋女人av噜噜色| 国产精品亚洲а∨天堂免| 91精品国产麻豆国产| 国产日韩精品一二三区久久久| 亚洲国产在人线放午夜| 美女操逼免费短视频下载链接| 精品亚洲国产中文自在线| 日韩不卡中文在线视频网站| 午夜免费体验区在线观看 | 大鸡巴操b视频在线| 亚洲精品av在线观看| 直接观看免费黄网站| 春色激情网欧美成人| 欧美日韩激情啪啪啪| 欧美日本国产自视大全| 国产黄色a级三级三级三级| 日本女大学生的黄色小视频| 国产女人叫床高潮大片视频| 蜜桃久久久久久久人妻| 日本免费午夜视频网站| 夜女神免费福利视频| 激情综合治理六月婷婷| 黄色大片免费观看网站| 天堂女人av一区二区| 大黑人性xxxxbbbb| 特黄老太婆aa毛毛片| 经典国语激情内射视频| 日本三极片中文字幕| 精品高跟鞋丝袜一区二区| 国产精品久久9999| 大屁股肉感人妻中文字幕在线| 国产精品自拍偷拍a| 欧洲亚洲欧美日韩综合| 99热这里只有精品中文| 天天日天天干天天干天天日| 在线免费观看靠比视频的网站| 婷婷六月天中文字幕| 国产一区av澳门在线观看| 黄页网视频在线免费观看 | 韩国三级aaaaa高清视频| aⅴ五十路av熟女中出| 中文字幕 亚洲av| 黑人解禁人妻叶爱071| 国产美女一区在线观看| lutube在线成人免费看| 亚洲午夜电影之麻豆| 国产在线观看免费人成短视频| 久草视频首页在线观看| 熟女在线视频一区二区三区| 亚洲av琪琪男人的天堂| 青青青国产片免费观看视频| 国产成人午夜精品福利| 久久久久只精品国产三级| 一区二区免费高清黄色视频| 国产在线自在拍91国语自产精品| 天天插天天色天天日| 国产黄色a级三级三级三级| 午夜极品美女福利视频| 91精品啪在线免费| 日韩欧美一级精品在线观看| 91精品国产91久久自产久强| 国产美女精品福利在线| 91精品国产观看免费| 黑人变态深video特大巨大| 亚洲欧洲一区二区在线观看| 中文字幕高清资源站| 中文字幕一区二区三区蜜月| 久久精品视频一区二区三区四区| 97人妻夜夜爽二区欧美极品| 在线观看成人国产电影| www日韩毛片av| 人妻av无码专区久久绿巨人| av中文字幕网址在线| 午夜久久久久久久99| 精品国产午夜视频一区二区| 欧美成人黄片一区二区三区 | 快点插进来操我逼啊视频| 亚洲人妻av毛片在线| 91九色porny蝌蚪国产成人| 成人av天堂丝袜在线观看| 天天爽夜夜爽人人爽QC| 中国产一级黄片免费视频播放| 在线免费观看欧美小视频| 亚洲中文字字幕乱码| 青娱乐极品视频青青草| 在线观看视频网站麻豆| 天天日天天敢天天干| 国产品国产三级国产普通话三级| 亚洲熟女女同志女同| 久精品人妻一区二区三区| 顶级尤物粉嫩小尤物网站| 天天操天天干天天艹| 51精品视频免费在线观看| 夜鲁夜鲁狠鲁天天在线| 91国产在线视频免费观看| 日本丰满熟妇大屁股久久| 中文字幕综合一区二区| 97人人妻人人澡人人爽人人精品| 无码日韩人妻精品久久| 精品人妻伦一二三区久| 日本免费午夜视频网站| 熟女91pooyn熟女| 国产妇女自拍区在线观看| 国产视频网站一区二区三区| 久久尻中国美女视频| 亚洲美女自偷自拍11页| 欧美一区二区三区高清不卡tv| 人妻少妇精品久久久久久| 岛国黄色大片在线观看| 天天射夜夜操综合网| 国产黄网站在线观看播放| 人妻无码中文字幕专区| 日韩欧美中文国产在线| 91久久综合男人天堂| 欧美成人综合视频一区二区| 9色在线视频免费观看| 噜噜色噜噜噜久色超碰| 欧美老鸡巴日小嫩逼| 欧美黄片精彩在线免费观看| 中文字幕日本人妻中出| 亚洲激情av一区二区| 国产丰满熟女成人视频| 蜜桃视频17c在线一区二区| 57pao国产一区二区| 在线新三级黄伊人网| 开心 色 六月 婷婷| 在线观看成人国产电影| 少妇系列一区二区三区视频| 国产黑丝高跟鞋视频在线播放 | 国产变态另类在线观看| 亚洲乱码中文字幕在线| 晚上一个人看操B片| 久久精品国产23696| 男生舔女生逼逼视频| 91片黄在线观看喷潮| 美女日逼视频免费观看| 在线免费观看视频一二区| 五月婷婷在线观看视频免费| tube69日本少妇| 性感美女诱惑福利视频| 国产午夜男女爽爽爽爽爽视频| av高潮迭起在线观看| 888欧美视频在线| 91在线免费观看成人| 中文字幕乱码av资源| 污污小视频91在线观看| 成年人午夜黄片视频资源| 人妻最新视频在线免费观看| 无码国产精品一区二区高潮久久4| 亚洲激情av一区二区| 国产午夜男女爽爽爽爽爽视频 | 国产在线自在拍91国语自产精品| 成人性黑人一级av| 午夜青青草原网在线观看| 免费在线黄色观看网站| 91亚洲精品干熟女蜜桃频道| 综合精品久久久久97| 2022国产综合在线干| 久草极品美女视频在线观看| 老司机福利精品免费视频一区二区 | 视频一区二区在线免费播放| 色偷偷伊人大杳蕉综合网| 夜色17s精品人妻熟女| 国产精品久久久久网| 岛国免费大片在线观看| 青青尤物在线观看视频网站| 国产精品入口麻豆啊啊啊| 亚洲视频乱码在线观看| 色综合久久五月色婷婷综合 | 在线免费91激情四射| 91九色porny国产在线| 日本午夜福利免费视频| 国产女人叫床高潮大片视频| 亚洲 清纯 国产com| 精品欧美一区二区vr在线观看| 少妇高潮一区二区三区| 国产精彩福利精品视频| 18禁美女无遮挡免费| 欧美日韩激情啪啪啪| 日本裸体熟妇区二区欧美| 51精品视频免费在线观看| 欧美一区二区三区高清不卡tv| 人妻无码色噜噜狠狠狠狠色| 国产免费av一区二区凹凸四季| 欧美80老妇人性视频| 青青社区2国产视频| 亚洲精品久久综合久| 日韩人妻xxxxx| 日辽宁老肥女在线观看视频| 欧美久久久久久三级网| 一区二区久久成人网| 五十路熟女人妻一区二| 任你操任你干精品在线视频| 亚洲午夜电影之麻豆| 女生被男生插的视频网站| 日本黄在免费看视频| 晚上一个人看操B片| 久久亚洲天堂中文对白| 日韩精品中文字幕在线| 日韩剧情片电影在线收看| 国产一区二区欧美三区| 中文字幕奴隷色的舞台50| 亚洲综合色在线免费观看| 日本三极片视频网站观看| 午夜精品福利91av| 天堂av狠狠操蜜桃| 久久久久91精品推荐99| av老司机精品在线观看| 亚洲国产精品中文字幕网站| 自拍 日韩 欧美激情| 超pen在线观看视频公开97| 丰满熟女午夜福利视频| av视网站在线观看| 青青草视频手机免费在线观看| 日本少妇精品免费视频| av亚洲中文天堂字幕网| 最新日韩av传媒在线| 国产一线二线三线的区别在哪| 欧美精产国品一二三区| 99精品一区二区三区的区| av网站色偷偷婷婷网男人的天堂| 精品国产在线手机在线| 午夜免费体验区在线观看 | 91九色国产熟女一区二区| 少妇与子乱在线观看| av欧美网站在线观看| 午夜国产免费福利av| 三级黄色亚洲成人av| 亚洲人妻30pwc| 在线免费观看黄页视频| 黄色资源视频网站日韩| 日韩av免费观看一区| 黄色视频成年人免费观看| 国产97视频在线精品| 精品一区二区亚洲欧美| 亚洲成人免费看电影| 亚洲第一伊人天堂网| 亚洲偷自拍高清视频| 最新国产亚洲精品中文在线| 婷婷色中文亚洲网68| 老司机福利精品视频在线| 日日操综合成人av| 91亚洲国产成人精品性色| 青青青青青青青青青青草青青| 任我爽精品视频在线播放| 日韩亚国产欧美三级涩爱| 精品人妻伦一二三区久| 少妇露脸深喉口爆吞精| 亚洲欧美综合在线探花| 国语对白xxxx乱大交| 天天色天天舔天天射天天爽| 久久人人做人人妻人人玩精品vr| 伊人开心婷婷国产av| 超黄超污网站在线观看| 国产精选一区在线播放| 欧美韩国日本国产亚洲| 女蜜桃臀紧身瑜伽裤| 成人激情文学网人妻| 91试看福利一分钟| 激情内射在线免费观看| 一区二区三区四区中文| 亚洲免费成人a v| 国产女人被做到高潮免费视频| 久久精品久久精品亚洲人| 青青青青青青青青青国产精品视频| 亚洲免费视频欧洲免费视频| 一区二区三区国产精选在线播放| 日韩精品激情在线观看| 中文字幕在线永久免费播放| 岛国免费大片在线观看| 成人免费毛片aaaa| 日韩欧美制服诱惑一区在线| 黄色的网站在线免费看| 日韩无码国产精品强奸乱伦| 亚洲熟妇无码一区二区三区| 极品性荡少妇一区二区色欲| 超级福利视频在线观看| 一区二区三区四区五区性感视频 | 青青青青青青草国产| 亚洲av色香蕉一区二区三区| 亚洲少妇高潮免费观看| 色综合天天综合网国产成人| www日韩a级s片av| 日本五十路熟新垣里子| 成人国产小视频在线观看| 最新中文字幕乱码在线| 日韩欧美国产精品91| brazzers欧熟精品系列| 日本三极片中文字幕| 天天日天天爽天天干| 五色婷婷综合狠狠爱| 男人的天堂一区二区在线观看| 在线视频免费观看网| 在线视频自拍第三页| 亚洲成人国产av在线| 午夜美女少妇福利视频| 91 亚洲视频在线观看| 免费在线黄色观看网站| 久久一区二区三区人妻欧美| 午夜毛片不卡免费观看视频| 国产日本欧美亚洲精品视| 青娱乐最新视频在线| 老熟妇xxxhd老熟女| 日本熟女50视频免费| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 欧洲亚洲欧美日韩综合| 熟女俱乐部一二三区| 在线观看911精品国产| 天天干天天搞天天摸| 亚洲蜜臀av一区二区三区九色| 国产综合高清在线观看| 欧美成人小视频在线免费看| 青青青视频自偷自拍38碰| 91久久精品色伊人6882| 啊啊好慢点插舔我逼啊啊啊视频| 人妻丝袜精品中文字幕| 日本后入视频在线观看| 51国产偷自视频在线播放| 欧美一区二区三区乱码在线播放| 欧洲黄页网免费观看| 美日韩在线视频免费看| 欧美性受xx黑人性猛交| av老司机精品在线观看| 国产亚洲四十路五十路| 国产夫妻视频在线观看免费| 97a片免费在线观看| 护士特殊服务久久久久久久| 成人综合亚洲欧美一区| 午夜福利人人妻人人澡人人爽| 超碰中文字幕免费观看| 99re6热在线精品| 欧美一区二区三区激情啪啪啪| 老师让我插进去69AV| 久久久久久97三级| 一本一本久久a久久精品综合不卡 亚洲另类综合一区小说 | 亚洲一区二区三区精品乱码| 男女啪啪视频免费在线观看| 亚洲天堂精品福利成人av| 午夜精品一区二区三区4| 欧美偷拍亚洲一区二区| 欧美地区一二三专区| 最新中文字幕免费视频| 国产女人露脸高潮对白视频 | 老鸭窝日韩精品视频观看| 538精品在线观看视频| 亚洲 色图 偷拍 欧美| 韩国黄色一级二级三级| 日本五十路熟新垣里子| 在线观看av观看av| 国产超码片内射在线| caoporn蜜桃视频| 人人妻人人爽人人澡人人精品| 国产va精品免费观看| 亚洲午夜高清在线观看| 综合激情网激情五月天| 91人妻精品久久久久久久网站| 日韩美女搞黄视频免费| 十八禁在线观看地址免费| 91精品国产黑色丝袜| 日韩av中文在线免费观看 | 青青色国产视频在线| 小泽玛利亚视频在线观看| 亚洲综合乱码一区二区| 宅男噜噜噜666国产| 在线免费观看靠比视频的网站| 2020中文字幕在线播放| 国产夫妻视频在线观看免费| 久久这里只有精品热视频| 午夜精品福利一区二区三区p| 欧美特色aaa大片| 色呦呦视频在线观看视频| 18禁免费av网站| 午夜久久久久久久精品熟女| 久久农村老妇乱69系列| 人人超碰国字幕观看97| 国产黄色高清资源在线免费观看| 强行扒开双腿猛烈进入免费版| 亚洲国产美女一区二区三区软件| 亚洲乱码中文字幕在线| 亚洲国产在人线放午夜| 91在线视频在线精品3| 黑人变态深video特大巨大| 亚洲熟色妇av日韩熟色妇在线| 人妻熟女中文字幕aⅴ在线| 精品久久久久久高潮| 久久h视频在线观看| 国产三级精品三级在线不卡| 日本熟女精品一区二区三区| 亚洲av日韩精品久久久| 99精品国产免费久久| 欧美日韩精品永久免费网址| 亚洲男人的天堂a在线| 在线观看免费视频色97| 中国视频一区二区三区| 动色av一区二区三区| 亚洲国产精品美女在线观看| a v欧美一区=区三区| 麻豆精品成人免费视频| 99精品国产自在现线观看| 99热久久这里只有精品| 和邻居少妇愉情中文字幕| 久草电影免费在线观看| 日本熟妇色熟妇在线观看| tube69日本少妇| 久久久制服丝袜中文字幕| 新97超碰在线观看| 国产janese在线播放| 国产视频网站一区二区三区| 99的爱精品免费视频| 国产日韩一区二区在线看| 中文字母永久播放1区2区3区| 亚洲中文字幕综合小综合| 国产免费高清视频视频| 亚洲av日韩精品久久久久久hd| 精品欧美一区二区vr在线观看| 成人动漫大肉棒插进去视频| 2020国产在线不卡视频| 91中文字幕免费在线观看| 黄片三级三级三级在线观看| 欧美老鸡巴日小嫩逼| 国产中文精品在线观看| 成人免费毛片aaaa| 成人国产小视频在线观看| 欧美成一区二区三区四区| 久久人人做人人妻人人玩精品vr| 欧美80老妇人性视频| 污污小视频91在线观看| 岛国免费大片在线观看| 黑人解禁人妻叶爱071| 一区二区在线视频中文字幕| 色97视频在线播放| 天天干夜夜操啊啊啊| 97人人妻人人澡人人爽人人精品| 黄色资源视频网站日韩| 国产亚洲精品视频合集| 国产精品视频欧美一区二区| 天天操夜夜操天天操天天操| 色综合久久久久久久久中文| 蜜桃视频入口久久久| 成人30分钟免费视频| 大尺度激情四射网站| 免费看国产又粗又猛又爽又黄视频| 成年美女黄网站18禁久久| 久久亚洲天堂中文对白| 日本五十路熟新垣里子| 韩国爱爱视频中文字幕| 美日韩在线视频免费看| 97超碰免费在线视频| 国产使劲操在线播放| www骚国产精品视频| 日本www中文字幕| 521精品视频在线观看| 视频一区 二区 三区 综合| 日本脱亚入欧是指什么| 午夜青青草原网在线观看| 亚洲欧美自拍另类图片| 在线观看视频一区麻豆| 日韩人妻丝袜中文字幕| 欧美日本国产自视大全| 成年午夜免费无码区| 青青青青操在线观看免费| 日韩国产乱码中文字幕| 亚洲欧美激情国产综合久久久| 国产三级精品三级在线不卡| 亚洲综合乱码一区二区| 自拍偷拍日韩欧美亚洲| 色综合色综合色综合色| 国产大鸡巴大鸡巴操小骚逼小骚逼| 午夜精品亚洲精品五月色| 美女福利视频网址导航| 99re国产在线精品| 丝袜美腿视频诱惑亚洲无| 欧美精品激情在线最新观看视频| 一区二区视频在线观看视频在线| 日本少妇人妻xxxxx18| 欧美美女人体视频一区| 黑人变态深video特大巨大| 97超碰人人搞人人| 亚洲综合色在线免费观看| 欧美成人猛片aaaaaaa| av天堂中文免费在线| 夜夜嗨av蜜臀av| 亚洲国产在线精品国偷产拍| 欧美日韩熟女一区二区三区| 农村胖女人操逼视频| 免费高清自慰一区二区三区网站| 风流唐伯虎电视剧在线观看| 亚洲1069综合男同| 只有精品亚洲视频在线观看| 国产精品系列在线观看一区二区 | 在线亚洲天堂色播av电影| 亚洲成人av一区久久| 欧美熟妇一区二区三区仙踪林| 精品黑人一区二区三区久久国产| 老师啊太大了啊啊啊尻视频| 黄片色呦呦视频免费看| 丰满的继坶3中文在线观看| 日本少妇在线视频大香蕉在线观看| 欧美老鸡巴日小嫩逼| 2025年人妻中文字幕乱码在线| 最后99天全集在线观看| mm131美女午夜爽爽爽| 老有所依在线观看完整版| 精品人妻一二三区久久| 激情色图一区二区三区| 在线观看的a站 最新| 人妻在线精品录音叫床| 国产九色91在线视频| 欧美中文字幕一区最新网址 | 亚洲精品国偷自产在线观看蜜桃| 在线免费91激情四射 | 久久久久五月天丁香社区| 色哟哟国产精品入口| 午夜91一区二区三区| 美女在线观看日本亚洲一区| 最近中文2019年在线看| 视频一区二区三区高清在线| 99精品免费久久久久久久久a| 日本a级视频老女人| 国产成人自拍视频播放| 高清成人av一区三区| 97人人模人人爽人人喊| 日韩a级黄色小视频| 国产日韩精品免费在线| 91国内精品久久久久精品一| 宅男噜噜噜666免费观看| 强行扒开双腿猛烈进入免费版| 80电影天堂网官网| 国产又粗又猛又爽又黄的视频美国| 91‖亚洲‖国产熟女| 麻豆性色视频在线观看| 亚洲精品国产综合久久久久久久久| 日韩美女福利视频网| 一区二区视频在线观看免费观看| 青青青激情在线观看视频| 老司机福利精品免费视频一区二区 | 欧美美女人体视频一区| 91久久国产成人免费网站| 中文字日产幕乱六区蜜桃| 天天插天天色天天日| 国产视频一区二区午夜| 中文字幕 亚洲av| 国产1区,2区,3区| 亚洲av香蕉一区区二区三区犇| jiujiure精品视频在线| 日韩中文字幕精品淫| 午夜婷婷在线观看视频| av天堂资源最新版在线看| 少妇人妻久久久久视频黄片| 2018最新中文字幕在线观看| 国产精品视频男人的天堂| 国产精品手机在线看片| 国产精彩对白一区二区三区| 天天插天天色天天日| 顶级尤物粉嫩小尤物网站| 91 亚洲视频在线观看| 在线免费91激情四射| 国产女人被做到高潮免费视频 | 国产刺激激情美女网站| 唐人色亚洲av嫩草| 99精品视频在线观看免费播放| 福利午夜视频在线观看| 毛片av在线免费看| av中文字幕福利网| 精品黑人巨大在线一区| 欲乱人妻少妇在线视频裸| 国产高清97在线观看视频| 日韩欧美一级精品在线观看| 97香蕉碰碰人妻国产樱花| 婷婷久久久久深爱网| 视频啪啪啪免费观看| 中文字幕av熟女人妻| 91大屁股国产一区二区| 国产女人被做到高潮免费视频 | 77久久久久国产精产品| 一色桃子久久精品亚洲| 欧美一级视频一区二区| 激情国产小视频在线| 一本久久精品一区二区| 人人妻人人澡人人爽人人dvl| 人人人妻人人澡人人| 精品一区二区亚洲欧美| 干逼又爽又黄又免费的视频| 18禁污污污app下载| 日日夜夜狠狠干视频| 中文字幕无码一区二区免费| 国内自拍第一页在线观看| 国产精品日韩欧美一区二区| 国产在线拍揄自揄视频网站| 丰满熟女午夜福利视频| 一区二区熟女人妻视频| 国产熟妇一区二区三区av| 在线观看黄色成年人网站| 精品久久久久久久久久久99| 国产白袜脚足J棉袜在线观看| 天天插天天狠天天操| 久久精品在线观看一区二区| 一区二区三区av高清免费| 日韩美av高清在线| 国产变态另类在线观看| 亚洲码av无色中文| 男人天堂色男人av| 日韩人妻xxxxx| 午夜av一区二区三区| 国产精品伦理片一区二区| 国产免费av一区二区凹凸四季| 大屁股肉感人妻中文字幕在线| 国产密臀av一区二区三| 亚洲乱码中文字幕在线| 亚洲综合色在线免费观看| 9色在线视频免费观看| 亚洲欧美日韩视频免费观看| 男人的网址你懂的亚洲欧洲av| 中文字幕 码 在线视频| 国产精品女邻居小骚货| 成人av久久精品一区二区| 18禁精品网站久久| 国产janese在线播放| 日本人妻少妇18—xx| 亚洲 欧美 精品 激情 偷拍| 国产精品久久久久久久久福交| 国产精品中文av在线播放 | 在线视频国产欧美日韩| 香港一级特黄大片在线播放| 又粗又硬又猛又爽又黄的| 99久久久无码国产精品性出奶水| 中文字幕视频一区二区在线观看| 中文字幕亚洲久久久| 亚洲综合在线视频可播放| h国产小视频福利在线观看| 国产在线观看黄色视频| 男人操女人的逼免费视频| 97年大学生大白天操逼| 亚洲公开视频在线观看| 黄色大片免费观看网站| 性感美女高潮视频久久久| 97小视频人妻一区二区| 揄拍成人国产精品免费看视频| 五月激情婷婷久久综合网| 中文字幕日韩精品就在这里| 在线网站你懂得老司机| 亚洲精品福利网站图片| 91久久人澡人人添人人爽乱| 啊啊好慢点插舔我逼啊啊啊视频| 精品一线二线三线日本| 2022国产精品视频| 国产精品欧美日韩区二区| 偷偷玩弄新婚人妻h视频| 清纯美女在线观看国产| 精品亚洲在线免费观看| 999久久久久999| 天天干狠狠干天天操| 美女福利视频导航网站| 小穴多水久久精品免费看| 国产精品视频资源在线播放| 色婷婷久久久久swag精品| 天天干天天操天天爽天天摸| 欧美精品资源在线观看| 99人妻视频免费在线| 一区二区三区av高清免费| 亚洲一级av大片免费观看| 国产三级精品三级在线不卡| 18禁污污污app下载| 一区二区在线观看少妇| 无套猛戳丰满少妇人妻| 97超碰最新免费在线观看| 日本男女操逼视频免费看| 亚洲午夜电影之麻豆| 国产精品一区二区久久久av| 亚洲无码一区在线影院| 日本免费一级黄色录像| 亚洲av色香蕉一区二区三区| 熟女视频一区,二区,三区| 中文字幕综合一区二区| 日本福利午夜电影在线观看| 天天干天天操天天爽天天摸| 午夜精品一区二区三区4| 91大神福利视频网| 夜夜嗨av蜜臀av| 欧美精品黑人性xxxx| 人人妻人人澡人人爽人人dvl| 天天日天天操天天摸天天舔| 2021国产一区二区| 瑟瑟视频在线观看免费视频| 在线观看亚洲人成免费网址| 天天艹天天干天天操| 在线成人日韩av电影| 天天通天天透天天插| 大肉大捧一进一出好爽在线视频| av网站色偷偷婷婷网男人的天堂| 亚洲在线观看中文字幕av| 精品一区二区三区三区色爱| 人妻久久久精品69系列| 久久久久久久一区二区三| 中文字幕日韩精品就在这里| 一级a看免费观看网站| 国产精品一区二区久久久av| 自拍偷拍亚洲欧美在线视频| 男人插女人视频网站| 国产精品黄片免费在线观看| 青青色国产视频在线| 亚洲欧美激情人妻偷拍| 韩国爱爱视频中文字幕| 大香蕉大香蕉大香蕉大香蕉大香蕉| 美女小视频网站在线| 婷婷综合亚洲爱久久| 亚洲天堂av最新网址| 在线免费观看欧美小视频| 国产精品久久久黄网站| 一区二区三区四区五区性感视频| 天天艹天天干天天操| 午夜免费观看精品视频| 大鸡吧插入女阴道黄色片| 午夜国产免费福利av| 亚洲高清一区二区三区视频在线| 中文字幕 码 在线视频| 97超碰免费在线视频| 国产精品精品精品999| 天美传媒mv视频在线观看| 天天干天天啪天天舔| 91在线视频在线精品3| 日韩少妇人妻精品无码专区| 日本丰满熟妇大屁股久久| 亚洲欧美精品综合图片小说| 在线免费观看99视频| 国产综合视频在线看片| 五月色婷婷综合开心网4438| 亚洲嫩模一区二区三区| 黑人性生活视频免费看| 人妻av无码专区久久绿巨人| 人妻凌辱欧美丰满熟妇| 姐姐的朋友2在线观看中文字幕| 一级黄片大鸡巴插入美女 | 亚洲一区二区三区uij| 日本免费一级黄色录像| 亚洲精品 欧美日韩| 这里有精品成人国产99| 午夜久久久久久久精品熟女| 亚洲成人免费看电影| 久久一区二区三区人妻欧美| 人妻无码中文字幕专区| 伊人综合免费在线视频| 色哟哟国产精品入口| 亚洲公开视频在线观看| 美女大bxxxx内射| 93视频一区二区三区| 国产又粗又硬又猛的毛片视频 | av完全免费在线观看av| 一区二区三区国产精选在线播放| 91超碰青青中文字幕| 性欧美日本大妈母与子| 人人在线视频一区二区| 香蕉片在线观看av| 中文字幕在线一区精品| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 国产视频在线视频播放| 国产日韩一区二区在线看 | 蜜桃久久久久久久人妻| 欧美精品国产综合久久| 久久精品美女免费视频| 99精品视频之69精品视频 | 亚洲中文字幕人妻一区| 国产精彩福利精品视频| 91人妻精品久久久久久久网站| 日本脱亚入欧是指什么| 欧美va亚洲va天堂va| 爱有来生高清在线中文字幕| 搞黄色在线免费观看| 色av色婷婷人妻久久久精品高清 | 在线视频精品你懂的| 亚洲国产精品黑丝美女| 扒开腿挺进肉嫩小18禁视频| 亚洲中文字幕综合小综合| 桃色视频在线观看一区二区| 19一区二区三区在线播放| 在线观看的a站 最新| 国产精品久久久久久久精品视频| 亚洲 中文 自拍 无码| 免费黄页网站4188| 免费高清自慰一区二区三区网站| 91福利在线视频免费观看| 韩国三级aaaaa高清视频| 韩国女主播精品视频网站| 新婚人妻聚会被中出| 激情五月婷婷免费视频| av无限看熟女人妻另类av| 免费啪啪啪在线观看视频| 年轻的人妻被夫上司侵犯| 亚洲超碰97人人做人人爱| 欧美伊人久久大香线蕉综合| 欧美亚洲牲夜夜综合久久| 亚洲综合一区成人在线| 在线观看视频污一区| 青青青青在线视频免费观看| 自拍偷拍日韩欧美亚洲| 亚洲人妻av毛片在线| 韩国黄色一级二级三级| 精品久久久久久久久久久a√国产| 精品黑人一区二区三区久久国产 | 2020av天堂网在线观看| 人妻少妇精品久久久久久| 欧美亚洲一二三区蜜臀| 美女骚逼日出水来了| lutube在线成人免费看| 青草久久视频在线观看| 欧美成人一二三在线网| 玩弄人妻熟妇性色av少妇| 国产真实灌醉下药美女av福利| 乱亲女秽乱长久久久| 一区国内二区日韩三区欧美| 国产视频精品资源网站| 97青青青手机在线视频| 99精品视频在线观看婷婷| 久久久久久国产精品| 人妻无码色噜噜狠狠狠狠色| 2025年人妻中文字幕乱码在线 | 国产一区二区神马久久| 欧亚乱色一区二区三区| 亚洲福利天堂久久久久久| 精品视频国产在线观看| 国产日韩欧美美利坚蜜臀懂色| 成人伊人精品色xxxx视频| 操日韩美女视频在线免费看| 日本美女性生活一级片| 超黄超污网站在线观看| 婷婷综合亚洲爱久久| 亚洲av可乐操首页| 国产chinesehd精品麻豆| 老司机福利精品免费视频一区二区| 18禁美女黄网站色大片下载| 天天色天天爱天天爽| 青青操免费日综合视频观看| 国产亚洲天堂天天一区| 国产老熟女伦老熟妇ⅹ| 亚洲欧美日韩视频免费观看| 久久久精品欧洲亚洲av| 国产内射中出在线观看| 日本韩国亚洲综合日韩欧美国产| 唐人色亚洲av嫩草| 伊人开心婷婷国产av| 国产精品人妻66p| 偷拍自拍国产在线视频| 国产又粗又猛又爽又黄的视频美国| 99久久超碰人妻国产| 99精品国自产在线人| 少妇ww搡性bbb91| 精品一区二区三区三区88| 亚洲av可乐操首页| 国产大学生援交正在播放| 日韩特级黄片高清在线看| 中文字幕在线一区精品| 91久久精品色伊人6882| 亚洲卡1卡2卡三卡四老狼| 好太好爽好想要免费| 啊啊啊想要被插进去视频| 阴茎插到阴道里面的视频| 久久尻中国美女视频| 大骚逼91抽插出水视频| 黑人大几巴狂插日本少妇| 天天插天天狠天天操| 国产a级毛久久久久精品| 福利视频广场一区二区| 热99re69精品8在线播放| 硬鸡巴动态操女人逼视频| 国产精品午夜国产小视频| 人妻少妇中文有码精品| 国产91精品拍在线观看| 久久丁香花五月天色婷婷| 91极品新人『兔兔』精品新作| 国产高清97在线观看视频| 男人的网址你懂的亚洲欧洲av| 2021天天色天天干| 在线国产日韩欧美视频| 91中文字幕最新合集| 在线国产中文字幕视频| 人妻3p真实偷拍一二区| 亚洲综合一区二区精品久久| 91自产国产精品视频| 少妇高潮无套内谢麻豆| 亚洲成人情色电影在线观看| 亚洲av日韩av第一区二区三区| 在线观看免费岛国av| av中文字幕福利网| 一区二区三区四区视频在线播放| 久久精品亚洲国产av香蕉| 后入美女人妻高清在线| 91精品国产黑色丝袜| 黄色av网站免费在线| 亚洲中文精品字幕在线观看| 91成人精品亚洲国产| 国产精品国色综合久久| jiuse91九色视频| 91成人精品亚洲国产| 精品高跟鞋丝袜一区二区| 亚洲综合在线视频可播放| 精品suv一区二区69| 日韩黄色片在线观看网站| 久久久久久久精品老熟妇| 亚洲卡1卡2卡三卡四老狼| 天天干夜夜操天天舔| 国产精品人妻熟女毛片av久| 日韩精品一区二区三区在线播放| av线天堂在线观看| 久久永久免费精品人妻专区| 青青青青青青青在线播放视频| 黑人性生活视频免费看| avjpm亚洲伊人久久| 久久丁香婷婷六月天| 在线国产中文字幕视频| 国产精品视频男人的天堂| 538精品在线观看视频| 国产成人自拍视频在线免费观看| 精品成人啪啪18免费蜜臀| 中英文字幕av一区| 1000小视频在线| 日本人妻精品久久久久久| 亚洲人妻国产精品综合| 国产美女精品福利在线| 日本少妇人妻xxxxx18| 国产a级毛久久久久精品| 国内自拍第一页在线观看| 在线观看欧美黄片一区二区三区| 在线免费观看欧美小视频| 男人和女人激情视频| 欧美一级片免费在线成人观看| 精品欧美一区二区vr在线观看| 桃色视频在线观看一区二区| 欧美久久久久久三级网| 日本av熟女在线视频| 人人妻人人澡人人爽人人dvl| 亚洲蜜臀av一区二区三区九色 | 扒开让我视频在线观看| 啊啊好大好爽啊啊操我啊啊视频| 一级a看免费观看网站| 青青草原网站在线观看| 亚洲欧美久久久久久久久| 性色蜜臀av一区二区三区| 大香蕉伊人中文字幕| 亚洲天堂精品久久久| 丝袜美腿视频诱惑亚洲无| 亚洲一区二区三区精品视频在线| 97超碰人人搞人人| 亚洲人人妻一区二区三区| 成年人中文字幕在线观看| 亚洲精品一区二区三区老狼| 黄色录像鸡巴插进去| 1区2区3区4区视频在线观看| 中文字幕第1页av一天堂网| 黄片三级三级三级在线观看| 亚洲欧美福利在线观看| 99的爱精品免费视频| 中文字幕一区二 区二三区四区| 天天想要天天操天天干| 欧美一区二区三区高清不卡tv | 国产精品入口麻豆啊啊啊| 色综合天天综合网国产成人| 亚洲精品无码久久久久不卡| 亚洲中文字字幕乱码| 亚洲精品麻豆免费在线观看| 视频一区 二区 三区 综合| 亚洲va欧美va人人爽3p| 亚洲2021av天堂| 亚洲国产美女一区二区三区软件| 成年人黄视频在线观看| 日韩av大胆在线观看| 精品少妇一二三视频在线| 日韩不卡中文在线视频网站| 99精品久久久久久久91蜜桃| 在线观看亚洲人成免费网址| 在线观看黄色成年人网站 | 超碰97人人澡人人| 女同久久精品秋霞网| 狠狠操操操操操操操操操| 91超碰青青中文字幕| 视频久久久久久久人妻| 欧美一区二区三区在线资源| 精品av国产一区二区三区四区| 中文字幕1卡1区2区3区| 日韩欧美中文国产在线| 色婷婷综合激情五月免费观看| 夜夜躁狠狠躁日日躁麻豆内射 | 久久美欧人妻少妇一区二区三区 | 熟女妇女老妇一二三区| 婷婷色国产黑丝少妇勾搭AV| 久久久久久久精品成人热| 欧美3p在线观看一区二区三区| 在线免费观看视频一二区| 午夜大尺度无码福利视频| 日韩av中文在线免费观看| 国产熟妇一区二区三区av| nagger可以指黑人吗| 成人蜜桃美臀九一一区二区三区| 全国亚洲男人的天堂| 国产va在线观看精品| 操日韩美女视频在线免费看 | 91精品啪在线免费| 国产极品精品免费视频| 粗大的内捧猛烈进出爽大牛汉子| 经典国语激情内射视频| av手机在线免费观看日韩av| 红杏久久av人妻一区| 精品美女福利在线观看| 人人妻人人澡人人爽人人dvl| 国产白嫩美女一区二区| 国产精品黄片免费在线观看| 欧美精品黑人性xxxx| 国产麻豆91在线视频| 偷青青国产精品青青在线观看| 888欧美视频在线| 丝袜美腿视频诱惑亚洲无| 国产精品免费不卡av| 99精品一区二区三区的区| 五十路老熟女码av| 久久精品亚洲成在人线a| 久草视频在线免播放| 大鸡吧插逼逼视频免费看| 中文字幕熟女人妻久久久| 色花堂在线av中文字幕九九| av天堂中文字幕最新| 成人av在线资源网站| 国产精品中文av在线播放| 国产成人无码精品久久久电影| 91 亚洲视频在线观看| 中文字幕网站你懂的| 三上悠亚和黑人665番号| 亚洲图片偷拍自拍区| 日本18禁久久久久久| 亚洲码av无色中文| 少妇与子乱在线观看| 2018最新中文字幕在线观看| 亚洲福利精品福利精品福利| 美女在线观看日本亚洲一区| 成人H精品动漫在线无码播放| 偷拍自拍视频图片免费| 精品人妻伦一二三区久| 黄色片黄色片wyaa| 国语对白xxxx乱大交| av成人在线观看一区| 在线观看的黄色免费网站| 毛片一级完整版免费| aⅴ精产国品一二三产品| 欧美视频中文一区二区三区| 大胆亚洲av日韩av| 91色九色porny| 超pen在线观看视频公开97 | 欧美国产亚洲中英文字幕| 18禁免费av网站| 欧美视频不卡一区四区| 国产日韩av一区二区在线| www天堂在线久久| 在线观看免费岛国av| 亚欧在线视频你懂的| 久草视频在线免播放| 天天色天天爱天天爽| gay gay男男瑟瑟在线网站| 中文字幕日韩精品日本| 91国内精品自线在拍白富美| 激情五月婷婷免费视频| 88成人免费av网站| 四川五十路熟女av| 亚洲男人在线天堂网| 亚洲一区二区三区av网站| 亚洲国产40页第21页| 男人在床上插女人视频| 欧美另类重口味极品在线观看| 日韩美女福利视频网| 国产精品女邻居小骚货| 一区二区三区久久中文字幕| 国产黄色大片在线免费播放| 老司机在线精品福利视频| 日韩精品电影亚洲一区| 人人爱人人妻人人澡39| 国产刺激激情美女网站| 人妻丝袜av在线播放网址| 大鸡吧插入女阴道黄色片| 精品高跟鞋丝袜一区二区| 九色精品视频在线播放| 老司机福利精品免费视频一区二区| 免费黄页网站4188| 国产丰满熟女成人视频| 中文字幕av熟女人妻| 国产三级精品三级在线不卡| 国产亚洲视频在线二区| 亚洲一区av中文字幕在线观看| 国产午夜男女爽爽爽爽爽视频| 青青青青青青青在线播放视频| 国产成人精品av网站| 天天操天天干天天日狠狠插| 91天堂天天日天天操| 成人午夜电影在线观看 久久| 欧美国品一二三产区区别| 日韩一区二区三区三州| 久久麻豆亚洲精品av| 亚洲2021av天堂| 人妻少妇亚洲精品中文字幕| 黄色片黄色片wyaa| 日韩欧美国产精品91| 亚洲一级特黄特黄黄色录像片| 又粗又硬又猛又爽又黄的| 姐姐的朋友2在线观看中文字幕| 丝袜长腿第一页在线| 瑟瑟视频在线观看免费视频| 大陆av手机在线观看| 婷婷久久久久深爱网| 中文字幕 亚洲av| 欧美地区一二三专区| 天天日天天日天天擦| 中文字幕在线观看极品视频| 又粗又硬又猛又黄免费30| 男人操女人的逼免费视频| 久久综合老鸭窝色综合久久| 99热99这里精品6国产| 国产在线拍揄自揄视频网站| 久久久人妻一区二区| 粉嫩av蜜乳av蜜臀| 国产在线自在拍91国语自产精品| 天天躁夜夜躁日日躁a麻豆| 欧美一区二区三区激情啪啪啪| 午夜福利人人妻人人澡人人爽| 精品suv一区二区69| 成人H精品动漫在线无码播放| 欧美亚洲少妇福利视频| 四虎永久在线精品免费区二区| 狠狠的往里顶撞h百合| 福利片区一区二体验区| 青青青激情在线观看视频| 啊用力插好舒服视频| 亚洲的电影一区二区三区| 欧美区一区二区三视频| 热久久只有这里有精品| 亚洲成人线上免费视频观看| 欧美老妇精品另类不卡片| 午夜成午夜成年片在线观看| 久久丁香花五月天色婷婷| 中国视频一区二区三区| 亚洲国产在人线放午夜| 99久久久无码国产精品性出奶水 | 欧美少妇性一区二区三区| 中国无遮挡白丝袜二区精品| 亚洲一区av中文字幕在线观看| 女生被男生插的视频网站| a v欧美一区=区三区| 成人伊人精品色xxxx视频| 亚洲专区激情在线观看视频| 男女第一次视频在线观看| 中文字幕日韩精品就在这里| 日韩不卡中文在线视频网站| 欧美一区二区三区激情啪啪啪 | 久久久久久久久久一区二区三区| 激情小视频国产在线| 夜鲁夜鲁狠鲁天天在线| 黄色三级网站免费下载| 国产精品视频一区在线播放| 亚洲日本一区二区久久久精品| 91精品一区二区三区站长推荐| 老司机午夜精品视频资源| 国产熟妇一区二区三区av| 天天干夜夜操啊啊啊| 亚洲日本一区二区久久久精品| 一级黄片久久久久久久久| 日日夜夜大香蕉伊人| 老鸭窝在线观看一区| 中文字幕人妻av在线观看| 亚洲成人精品女人久久久| av久久精品北条麻妃av观看| 国产高清在线观看1区2区| 国产在线观看免费人成短视频| 国产熟妇人妻ⅹxxxx麻豆| 亚洲国产精品久久久久蜜桃| 激情国产小视频在线| 小穴多水久久精品免费看| 国内自拍第一页在线观看| 亚洲熟女久久久36d| 中文字幕一区二区亚洲一区| 午夜精品九一唐人麻豆嫩草成人| 欧美偷拍自拍色图片| 2021久久免费视频| 黑人性生活视频免费看| 97超碰国语国产97超碰| 午夜久久久久久久99| 亚洲人妻30pwc| 国产中文精品在线观看| 黄网十四区丁香社区激情五月天 | 久久久久久久亚洲午夜综合福利| av黄色成人在线观看| 国产精品久久久久久美女校花| 91在线免费观看成人| av高潮迭起在线观看| 午夜大尺度无码福利视频| 综合精品久久久久97| 国产欧美精品不卡在线| 超级碰碰在线视频免费观看| 亚洲欧美激情人妻偷拍| 亚洲欧洲av天堂综合| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 欧美精品免费aaaaaa| 久久久极品久久蜜桃| 天天日天天日天天擦| 黄片大全在线观看观看| 成人伊人精品色xxxx视频| 精品国产高潮中文字幕| 99精品亚洲av无码国产另类| av天堂中文字幕最新| 国产卡一卡二卡三乱码手机| 久久精品国产999| av黄色成人在线观看| 国产精品午夜国产小视频| 成人综合亚洲欧美一区| 9色在线视频免费观看| 亚洲伊人久久精品影院一美女洗澡 | 97人妻无码AV碰碰视频| 可以在线观看的av中文字幕| 综合色区亚洲熟妇shxstz| 少妇高潮无套内谢麻豆| 黄片大全在线观看观看| 熟女在线视频一区二区三区| 国产91精品拍在线观看| 日韩av免费观看一区| 亚洲在线免费h观看网站| 天天日夜夜干天天操| 88成人免费av网站| 天天操天天干天天艹| 青青尤物在线观看视频网站| av视屏免费在线播放| 一区二区久久成人网| 农村胖女人操逼视频| 欧美亚洲牲夜夜综合久久| 欧美另类z0z变态| 国产成人小视频在线观看无遮挡 | 日韩美女搞黄视频免费| 久久精品美女免费视频| 亚洲人妻国产精品综合| 日日操综合成人av| 婷婷久久久久深爱网| 一色桃子久久精品亚洲| 精产国品久久一二三产区区别 | 亚洲欧洲av天堂综合| 欧洲亚洲欧美日韩综合| 中字幕人妻熟女人妻a62v网 | 日韩无码国产精品强奸乱伦| 人妻无码中文字幕专区| 日本韩国免费福利精品| 欧美精产国品一二三产品区别大吗| 亚洲 中文 自拍 无码| 动漫美女的小穴视频| 欧洲欧美日韩国产在线| 日韩欧美在线观看不卡一区二区| 欧美天堂av无线av欧美| 成人综合亚洲欧美一区| 偷拍自拍亚洲视频在线观看| 自拍偷拍,中文字幕| 丰满的继坶3中文在线观看| 91久久综合男人天堂| 888亚洲欧美国产va在线播放| 一区二区麻豆传媒黄片| 11久久久久久久久久久| 国产福利小视频大全| 国产一区av澳门在线观看| 日本少妇高清视频xxxxx | 精品美女久久久久久| www日韩毛片av| 自拍偷拍亚洲欧美在线视频| 天天躁夜夜躁日日躁a麻豆| 欧美日本aⅴ免费视频| 福利视频网久久91| 一本久久精品一区二区| 日本午夜福利免费视频| 9色在线视频免费观看| 69精品视频一区二区在线观看| 亚洲一区二区激情在线| 一区二区三区四区五区性感视频| 男人和女人激情视频| 97年大学生大白天操逼| 北条麻妃高跟丝袜啪啪| rct470中文字幕在线| 成人24小时免费视频| 人人妻人人爱人人草| 午夜精品久久久久久99热| 亚洲一区制服丝袜美腿| 亚洲日产av一区二区在线| 91国内精品自线在拍白富美| 亚洲福利精品视频在线免费观看| 亚洲 中文 自拍 无码| 啪啪啪啪啪啪啪免费视频| 欧美激情电影免费在线| 成人国产影院在线观看| 黄色大片免费观看网站| 91社福利《在线观看| 欧美黄色录像免费看的| 日日夜夜精品一二三| 欧美日本国产自视大全| 亚洲欧美成人综合在线观看| 免费69视频在线看| 亚洲国产免费av一区二区三区| 欧美精产国品一二三产品区别大吗| 天天射夜夜操狠狠干| 在线观看国产免费麻豆| 一区二区三区av高清免费| 久草福利电影在线观看| 久久久91蜜桃精品ad| 大香蕉伊人中文字幕| 极品粉嫩小泬白浆20p主播| 久久三久久三久久三久久| 绝色少妇高潮3在线观看| 亚洲变态另类色图天堂网| av成人在线观看一区| 国产一级麻豆精品免费| av一本二本在线观看| 激情内射在线免费观看| 97瑟瑟超碰在线香蕉| 国产精品国产精品一区二区| 自拍偷拍亚洲欧美在线视频| 偷偷玩弄新婚人妻h视频| 在线制服丝袜中文字幕| 无码中文字幕波多野不卡| 欧美黑人巨大性xxxxx猛交| aiss午夜免费视频| 国产午夜男女爽爽爽爽爽视频| 成人乱码一区二区三区av| 午夜精品在线视频一区| 欧美日韩不卡一区不区二区| 黄色成人在线中文字幕| 中文字幕—97超碰网| 国产精品久久综合久久| 人妻熟女中文字幕aⅴ在线| 不戴胸罩引我诱的隔壁的人妻| 亚洲一级特黄特黄黄色录像片| 天天日天天玩天天摸| 亚洲av日韩av第一区二区三区| 黄色成年网站午夜在线观看| 在线播放一区二区三区Av无码| 日本特级片中文字幕| 亚洲中文字幕校园春色| 少妇深喉口爆吞精韩国| 免费黄色成人午夜在线网站| 午夜免费体验区在线观看| 777奇米久久精品一区| 999九九久久久精品| 免费无毒热热热热热热久| 亚洲另类综合一区小说| 风流唐伯虎电视剧在线观看| 国产精品一区二区av国| 久久h视频在线观看| 巨乳人妻日下部加奈被邻居中出| 欧洲亚洲欧美日韩综合| 天天操夜夜操天天操天天操| 久草极品美女视频在线观看| 含骚鸡巴玩逼逼视频| 天天操天天插天天色| 日韩人妻xxxxx| 国产高清精品极品美女| 亚洲自拍偷拍综合色| 老司机你懂得福利视频| 最新91九色国产在线观看| 欧美80老妇人性视频| 国产白袜脚足J棉袜在线观看| 毛片一级完整版免费| 久久这里只有精品热视频| 亚洲一级av无码一级久久精品| av乱码一区二区三区| 中文字母永久播放1区2区3区| 把腿张开让我插进去视频| 水蜜桃国产一区二区三区| 大鸡吧插逼逼视频免费看| 日日夜夜狠狠干视频| 国产97在线视频观看| 啪啪啪18禁一区二区三区| 国产一线二线三线的区别在哪 | 99热99这里精品6国产| 亚洲成人av在线一区二区| 亚洲一级特黄特黄黄色录像片| 视频一区二区在线免费播放| 成年人黄视频在线观看| av完全免费在线观看av| 福利国产视频在线观看| 亚洲av日韩精品久久久| 国产日本精品久久久久久久| 老熟妇凹凸淫老妇女av在线观看| 人妻熟女在线一区二区| 2020韩国午夜女主播在线| 国产日韩一区二区在线看| 免费十精品十国产网站| 欧洲欧美日韩国产在线| 日本一本午夜在线播放| 任你操视频免费在线观看| 免费在线看的黄网站| 亚洲日本一区二区三区| 99久久中文字幕一本人| 久久综合老鸭窝色综合久久| 狠狠的往里顶撞h百合| 91综合久久亚洲综合| 日本啪啪啪啪啪啪啪| 国产成人精品av网站| 日韩av熟妇在线观看| 国产精品自偷自拍啪啪啪| 日韩av有码一区二区三区4| 都市激情校园春色狠狠| 午夜精品九一唐人麻豆嫩草成人| 亚洲2021av天堂| 岛国一区二区三区视频在线| av老司机精品在线观看| 人妻无码中文字幕专区| 38av一区二区三区| 国产乱子伦一二三区| 日视频免费在线观看| 蜜桃臀av蜜桃臀av| 在线观看视频一区麻豆| 在线免费91激情四射 | 99精品久久久久久久91蜜桃| 换爱交换乱高清大片| 精品首页在线观看视频| 狠狠躁夜夜躁人人爽天天天天97| 亚洲免费视频欧洲免费视频| 91试看福利一分钟| 亚洲天天干 夜夜操| 国产精品大陆在线2019不卡| 一级黄片久久久久久久久| 精产国品久久一二三产区区别 | 激情啪啪啪啪一区二区三区| 老司机你懂得福利视频| okirakuhuhu在线观看| 久久亚洲天堂中文对白|