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

亚洲欧洲一区二区在线观看| 欧美中国日韩久久精品| 综合激情网激情五月五月婷婷| 97青青青手机在线视频| 日本熟女精品一区二区三区| 色伦色伦777国产精品| 日韩av熟妇在线观看| 在线观看一区二区三级| 九色porny九色9l自拍视频| 欧美日本国产自视大全| 亚洲精品国偷自产在线观看蜜桃| 免费黄页网站4188| 日韩美av高清在线| 欧美激情精品在线观看| 人妻无码中文字幕专区| 国产精品国产三级国产午| 国产视频精品资源网站| 欧美精品亚洲精品日韩在线| 日本欧美视频在线观看三区| 香港一级特黄大片在线播放 | 国产aⅴ一线在线观看| 欧洲日韩亚洲一区二区三区| 888欧美视频在线| 成人福利视频免费在线| 首之国产AV医生和护士小芳| 国产视频在线视频播放| 色综合久久五月色婷婷综合| 国产精品一区二区三区蜜臀av| 又粗又硬又猛又爽又黄的| 午夜精品福利一区二区三区p| 精品国产乱码一区二区三区乱| 亚洲国产最大av综合| 国产福利小视频大全| 不卡一区一区三区在线| 黑人巨大精品欧美视频| 九色porny九色9l自拍视频| 99热色原网这里只有精品| 午夜美女福利小视频| 丝袜长腿第一页在线| 亚洲精品国产综合久久久久久久久| 做爰视频毛片下载蜜桃视频1| 肏插流水妹子在线乐播下载| 蜜臀av久久久久久久| 国产va在线观看精品| 少妇人妻100系列| 天天摸天天日天天操| 北条麻妃高跟丝袜啪啪| 亚洲1区2区3区精华液| 韩国黄色一级二级三级| 欧美视频一区免费在线| 大屁股熟女一区二区三区| av老司机精品在线观看| 国产视频一区在线观看| 欧美精品免费aaaaaa| 青青青视频自偷自拍38碰| 激情色图一区二区三区| 92福利视频午夜1000看| 护士特殊服务久久久久久久| 五十路熟女av天堂| 日本人妻少妇18—xx| 二区中出在线观看老师| 午夜在线一区二区免费| 75国产综合在线视频| 五十路人妻熟女av一区二区| 日本后入视频在线观看 | 久久久久久久99精品| 在线观看的a站 最新| 绝色少妇高潮3在线观看| 黑人性生活视频免费看| 成人免费公开视频无毒| 免费在线黄色观看网站| 黄色片黄色片wyaa| 沙月文乃人妻侵犯中文字幕在线| 91精品国产91青青碰| 国产成人自拍视频播放| 免费在线观看视频啪啪| 伊人综合免费在线视频| 性感美女福利视频网站| 人妻另类专区欧美制服| av网址在线播放大全| 中文字幕第三十八页久久| 久久人人做人人妻人人玩精品vr| 天堂av狠狠操蜜桃| 东京热男人的av天堂| 国产精品黄片免费在线观看| 日本高清撒尿pissing| 亚洲中文字幕乱码区| 都市激情校园春色狠狠| 绝顶痉挛大潮喷高潮无码| 亚洲在线一区二区欧美| 大香蕉伊人国产在线| 国产精品人妻熟女毛片av久| 青青操免费日综合视频观看| 欧洲精品第一页欧洲精品亚洲| 熟女91pooyn熟女| 国产极品精品免费视频| 97人人模人人爽人人喊| 青青青青草手机在线视频免费看| 亚洲另类伦春色综合小| 中国熟女@视频91| 日本裸体熟妇区二区欧美| 国产亚洲视频在线二区| 动漫美女的小穴视频| 激情国产小视频在线| 精品亚洲中文字幕av| 春色激情网欧美成人| 熟女妇女老妇一二三区| 2022精品久久久久久中文字幕| 欧美成人综合色在线噜噜| 精品少妇一二三视频在线| 亚洲一区二区三区偷拍女厕91| 亚洲一区二区三区久久受| 国产污污污污网站在线| 熟女视频一区,二区,三区| 日本一区美女福利视频| 亚洲精品福利网站图片| 亚洲日产av一区二区在线| 亚洲黄色av网站免费播放| 国产黄色大片在线免费播放| 日韩影片一区二区三区不卡免费| 欧美亚洲中文字幕一区二区三区| 四川乱子伦视频国产vip| 顶级尤物粉嫩小尤物网站| 无码中文字幕波多野不卡| 久久这里有免费精品| 亚洲另类在线免费观看| 91精品国产91久久自产久强 | 亚洲国产美女一区二区三区软件| 综合页自拍视频在线播放| 黄页网视频在线免费观看| 天天日天天添天天爽| 黑人乱偷人妻中文字幕| 91精品国产黑色丝袜| 无码日韩人妻精品久久| 桃色视频在线观看一区二区 | 欧美精品一二三视频| 日韩美av高清在线| 国产中文精品在线观看| 国产揄拍高清国内精品对白| 福利视频一区二区三区筱慧| 岛国av高清在线成人在线| 99精品国产aⅴ在线观看| 人妻凌辱欧美丰满熟妇| 国产熟妇一区二区三区av| 夫妻在线观看视频91| 国产精品探花熟女在线观看| 班长撕开乳罩揉我胸好爽| 91老师蜜桃臀大屁股| 午夜婷婷在线观看视频| 国产免费av一区二区凹凸四季| 中文字幕第一页国产在线| 在线观看免费岛国av| 亚洲国产精品美女在线观看| asmr福利视频在线观看| 国产乱弄免费视频观看| 中文字幕亚洲久久久| 精品suv一区二区69| 中国黄片视频一区91| 大香蕉伊人中文字幕| 欧美日韩不卡一区不区二区| 亚洲欧美综合在线探花| 精品一区二区三区三区色爱| 久久艹在线观看视频| 神马午夜在线观看视频| 中文字幕中文字幕人妻| 动色av一区二区三区| 中文字幕av熟女人妻| 一区二区三区国产精选在线播放| 特级欧美插插插插插bbbbb| 人妻少妇中文有码精品| 国产一区二区欧美三区| 午夜激情高清在线观看| 在线可以看的视频你懂的| 国产片免费观看在线观看| 国产成人精品av网站| 人妻素人精油按摩中出| 欧美亚洲自偷自拍 在线| 亚洲欧美激情国产综合久久久| 国产视频网站国产视频| 精品人妻伦一二三区久| 天天操,天天干,天天射| 激情色图一区二区三区| 亚洲国产欧美一区二区三区…| sw137 中文字幕 在线| 美女大bxxxx内射| 天天干天天插天天谢| 日本www中文字幕| 精品一区二区三四区| 亚洲精品国偷自产在线观看蜜桃| 超级av免费观看一区二区三区| 日本福利午夜电影在线观看| 91快播视频在线观看| 成年午夜影片国产片| 免费在线看的黄网站| 色秀欧美视频第一页| 中文字幕一区二区人妻电影冢本 | 偷偷玩弄新婚人妻h视频| 亚洲蜜臀av一区二区三区九色 | 91免费黄片可看视频| 91色秘乱一区二区三区| 91片黄在线观看喷潮| 亚洲福利精品福利精品福利| 91成人精品亚洲国产| 黄色片黄色片wyaa| 91麻豆精品91久久久久同性| 91免费放福利在线观看| 92福利视频午夜1000看 | 国产福利小视频大全| 五月天久久激情视频| 欧美一级视频一区二区| 亚洲av在线观看尤物| japanese日本熟妇另类| 成人动漫大肉棒插进去视频| 蜜臀av久久久久久久| av中文在线天堂精品| 国产精品久久久久久美女校花| 熟女俱乐部一二三区| 日本美女性生活一级片| 蜜臀av久久久久久久| 欧美精品 日韩国产| 38av一区二区三区| 日韩欧美一级aa大片| 久久久久久久精品成人热| 欧美亚洲一二三区蜜臀| 天天做天天干天天操天天射| 馒头大胆亚洲一区二区| 青草久久视频在线观看| 在线观看视频网站麻豆| 日本www中文字幕| 日本女大学生的黄色小视频| 亚洲2021av天堂| 国产黑丝高跟鞋视频在线播放| 欧美在线偷拍视频免费看 | 成人av久久精品一区二区| 午夜精品亚洲精品五月色| 最新日韩av传媒在线| 欧美黑人性暴力猛交喷水| 999热精品视频在线| 天天做天天干天天舔| 精品一区二区三区在线观看| 国产综合高清在线观看| 91极品新人『兔兔』精品新作| 国产精品久久9999| 黄色的网站在线免费看| 五月天色婷婷在线观看视频免费| 在线国产日韩欧美视频| 国产高清97在线观看视频| 亚洲欧美一区二区三区电影| 亚洲国产欧美国产综合在线| 激情啪啪啪啪一区二区三区| 亚洲成人国产综合一区| 午夜毛片不卡免费观看视频| 精品suv一区二区69| 欧美一区二区三区激情啪啪啪| 91极品大一女神正在播放| 天天躁日日躁狠狠躁躁欧美av | 91国内精品自线在拍白富美| 美女骚逼日出水来了| 青草亚洲视频在线观看| 人妻熟女中文字幕aⅴ在线| 国产九色91在线观看精品| 亚洲图片偷拍自拍区| 亚洲欧美人精品高清| 亚洲av成人免费网站| 青青青aaaa免费| 偷拍3456eee| 午夜精品福利一区二区三区p| 伊人网中文字幕在线视频| 精品久久久久久久久久久a√国产| 91九色国产porny蝌蚪| 成人av免费不卡在线观看| 亚洲女人的天堂av| 99精品免费久久久久久久久a| 大鸡巴插入美女黑黑的阴毛| sw137 中文字幕 在线| 亚洲精品亚洲人成在线导航 | 国产一区二区火爆视频| 3344免费偷拍视频| 中文字幕第1页av一天堂网 | chinese国产盗摄一区二区| 亚洲av成人网在线观看| 欧美一区二区三区高清不卡tv| 国产又粗又硬又猛的毛片视频| 在线观看欧美黄片一区二区三区 | 天天日天天爽天天爽| 久久久精品精品视频视频| av中文字幕电影在线看| 成人国产影院在线观看| 一区二区三区四区视频在线播放| 日日摸夜夜添夜夜添毛片性色av| 9国产精品久久久久老师 | 精品国产亚洲av一淫| 91超碰青青中文字幕| 天天操天天操天天碰| 日本黄在免费看视频| 丰满少妇人妻xxxxx| 国产无遮挡裸体免费直播视频| 成人资源在线观看免费官网| 内射久久久久综合网| 在线播放 日韩 av| 中文字幕乱码av资源| 阴茎插到阴道里面的视频| 色噜噜噜噜18禁止观看| 偷青青国产精品青青在线观看| 福利视频广场一区二区| 欧亚乱色一区二区三区| 午夜福利资源综合激情午夜福利资 | 国产精选一区在线播放| 国产精品久久久久久久精品视频| 视频 一区二区在线观看| 亚洲国产精品免费在线观看| 91福利在线视频免费观看| 91国产资源在线视频| 亚洲av自拍偷拍综合| 乱亲女秽乱长久久久| 少妇系列一区二区三区视频| av在线免费观看亚洲天堂| 2019av在线视频| 黄色av网站免费在线| 亚洲av第国产精品| 最新的中文字幕 亚洲| 午夜久久久久久久99| 18禁网站一区二区三区四区| 2021国产一区二区| 久久久久久久久久性潮| 40道精品招牌菜特色| 青娱乐最新视频在线| 亚洲精品午夜久久久久| 天堂av在线播放免费| 亚洲欧美一区二区三区电影| 中文字幕AV在线免费看 | 五月激情婷婷久久综合网| 欧美区一区二区三视频| av一区二区三区人妻| 国产精品自拍偷拍a| 亚洲伊人色一综合网| 天堂v男人视频在线观看| 亚洲国产在线精品国偷产拍| 国产成人精品福利短视频| 在线成人日韩av电影| 美女在线观看日本亚洲一区| 天堂av在线官网中文| 福利午夜视频在线观看| 2o22av在线视频| 98精产国品一二三产区区别| 成年人免费看在线视频| 偷拍自拍视频图片免费| 午夜精品久久久久麻豆影视| 久久精品视频一区二区三区四区| 亚洲最大免费在线观看| 五十路av熟女松本翔子| 中文字幕免费在线免费| 色哟哟国产精品入口| 人妻丝袜诱惑我操她视频| yellow在线播放av啊啊啊| 蜜桃色婷婷久久久福利在线| 国产午夜福利av导航| 亚洲区欧美区另类最新章节| 日本熟妇喷水xxx| 红桃av成人在线观看| 日本一区美女福利视频| 伊人精品福利综合导航| 99久久99久国产黄毛片| 夜鲁夜鲁狠鲁天天在线| 午夜精品亚洲精品五月色| 五十路丰满人妻熟妇| 乱亲女秽乱长久久久| 91一区精品在线观看| 日本三极片视频网站观看| 一区二区三区的久久的蜜桃的视频| 端庄人妻堕落挣扎沉沦| 日韩国产乱码中文字幕| 少妇深喉口爆吞精韩国| 懂色av蜜桃a v| 国产午夜福利av导航| 国产日韩精品电影7777| 黑人借宿ntr人妻的沦陷2| 操人妻嗷嗷叫视频一区二区| 在线观看的黄色免费网站| 欧美成人综合色在线噜噜| 91九色porny国产蝌蚪视频| 成年人黄视频在线观看| 夜色福利视频在线观看| 自拍偷拍亚洲欧美在线视频| 欧美韩国日本国产亚洲| 国产精品女邻居小骚货| 国产精品探花熟女在线观看| 成人激情文学网人妻| 91精品激情五月婷婷在线| 又粗又长 明星操逼小视频| 久草视频在线看免费| 4个黑人操素人视频网站精品91| 亚洲欧洲av天堂综合| 另类av十亚洲av| 91人妻精品一区二区在线看| 亚洲综合在线视频可播放| 久久综合老鸭窝色综合久久| 日本少妇人妻xxxxx18| 国产a级毛久久久久精品| 顶级尤物粉嫩小尤物网站| 国产精品视频资源在线播放| 亚洲一区二区三区五区| 久久这里只有精彩视频免费| 亚洲精品国产在线电影| 一区二区三区国产精选在线播放| 绝色少妇高潮3在线观看| 国产janese在线播放| 欧美3p在线观看一区二区三区| 97人人模人人爽人人喊| 国产成人精品午夜福利训2021 | 9国产精品久久久久老师| 激情色图一区二区三区| 欧美老妇精品另类不卡片| 日韩北条麻妃一区在线| 激情色图一区二区三区| 午夜频道成人在线91| 欧美日本在线视频一区| 成人午夜电影在线观看 久久| 在线播放国产黄色av| 加勒比视频在线免费观看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 在线观看操大逼视频| 日本一二三区不卡无| 欧美天堂av无线av欧美| 老师让我插进去69AV| 青青青青爽手机在线| 日本黄在免费看视频| 美女 午夜 在线视频| 中文字幕人妻熟女在线电影| 青青青aaaa免费| 成人资源在线观看免费官网| 9国产精品久久久久老师| 99热99re在线播放| 国内自拍第一页在线观看| 热久久只有这里有精品| 91麻豆精品久久久久| 2020av天堂网在线观看| 最新国产精品网址在线观看| 成人高清在线观看视频| 涩涩的视频在线观看视频| 国产精品sm调教视频| 日本黄在免费看视频| 久久热这里这里只有精品| 亚洲av天堂在线播放| 人妻av无码专区久久绿巨人| gay gay男男瑟瑟在线网站| 玖玖一区二区在线观看| 日本精品视频不卡一二三| 动漫精品视频在线观看| 免费福利av在线一区二区三区| 久草视频中文字幕在线观看| 中文字幕 码 在线视频| 亚洲无线观看国产高清在线| mm131美女午夜爽爽爽| 自拍偷拍,中文字幕| 国产成人一区二区三区电影网站| 精品久久久久久久久久久a√国产| 激情内射在线免费观看| 亚洲一区二区三区久久午夜| 国产精品久久久黄网站| 亚洲成人国产av在线| 国产又粗又猛又爽又黄的视频美国| av视屏免费在线播放| 国产亚洲欧美45p| 好吊操视频这里只有精品| av完全免费在线观看av| 国产精品系列在线观看一区二区| 日本少妇高清视频xxxxx| 亚洲精品亚洲人成在线导航| 国产精品久久久久网| av资源中文字幕在线观看| 99精品久久久久久久91蜜桃| 亚洲变态另类色图天堂网| av中文字幕电影在线看| 天天日天天敢天天干| 亚洲av无码成人精品区辽| 色天天天天射天天舔| 97黄网站在线观看| 一区二区三区激情在线| 丝袜亚洲另类欧美变态| 老鸭窝在线观看一区| 蜜桃视频入口久久久| 日韩少妇人妻精品无码专区| 人人妻人人澡欧美91精品| 后入美女人妻高清在线| 日韩成人性色生活片| 免费看美女脱光衣服的视频| 欧美国品一二三产区区别| 成人av天堂丝袜在线观看| 亚洲精品国产在线电影| 9l人妻人人爽人人爽| 人人人妻人人澡人人| 亚洲欧美清纯唯美另类| 93视频一区二区三区| 亚洲午夜福利中文乱码字幕 | 97精品成人一区二区三区| 日本一道二三区视频久久| 国产又粗又猛又爽又黄的视频在线| 日本人妻欲求不满中文字幕| 92福利视频午夜1000看| 亚洲国产欧美国产综合在线| 成人精品视频99第一页| 日韩a级精品一区二区| 老司机深夜免费福利视频在线观看| 中文字幕一区二 区二三区四区 | 日本三极片中文字幕| 2020国产在线不卡视频| 亚洲专区激情在线观看视频| 自拍偷拍日韩欧美亚洲| AV无码一区二区三区不卡| 色狠狠av线不卡香蕉一区二区 | 亚洲福利午夜久久久精品电影网| 少妇人妻真实精品视频| 中文字幕无码一区二区免费| 欧美亚洲免费视频观看| 国产白嫩美女一区二区| 国产精品人妻熟女毛片av久| 日本少妇人妻xxxxxhd| 偷拍自拍 中文字幕| 精品久久久久久久久久久久人妻| 日韩一个色综合导航| 大鸡巴插入美女黑黑的阴毛| 无码中文字幕波多野不卡| 天堂av在线播放免费| 一区二区免费高清黄色视频| 在线观看一区二区三级| 国产午夜福利av导航| 婷婷久久一区二区字幕网址你懂得| 天天日天天敢天天干| 亚洲粉嫩av一区二区三区| 狠狠操狠狠操免费视频| 色婷婷久久久久swag精品| 一区二区在线视频中文字幕| jiujiure精品视频在线| 午夜美女少妇福利视频| 亚洲熟女久久久36d| 午夜激情久久不卡一区二区 | jul—619中文字幕在线| 好男人视频在线免费观看网站| 亚洲精品久久视频婷婷| 在线免费观看视频一二区| 亚洲一级av大片免费观看| 深夜男人福利在线观看| 91精品高清一区二区三区| 在线免费观看靠比视频的网站| 久草极品美女视频在线观看| 亚洲高清国产拍青青草原| 黄色av网站免费在线| 伊人精品福利综合导航| 91老师蜜桃臀大屁股| heyzo蜜桃熟女人妻| 日韩少妇人妻精品无码专区| 亚洲欧美激情中文字幕| 中文字幕一区二区人妻电影冢本 | 啪啪啪操人视频在线播放| 天天操,天天干,天天射| 激情人妻校园春色亚洲欧美| 福利视频一区二区三区筱慧| 欧美一区二区三区久久久aaa| 欧美色呦呦最新网址| 日韩精品中文字幕播放| 99热碰碰热精品a中文| 人妻素人精油按摩中出| 少妇高潮一区二区三区| 欧美日本在线视频一区| 最新中文字幕乱码在线| 中文字日产幕乱六区蜜桃| 免费高清自慰一区二区三区网站 | 果冻传媒av一区二区三区 | aⅴ精产国品一二三产品| 爱有来生高清在线中文字幕| 蜜臀av久久久久久久| 早川濑里奈av黑人番号| 亚洲欧美综合在线探花| 亚洲精品国产久久久久久| 国产又粗又猛又爽又黄的视频在线 | 中文字幕第三十八页久久 | 久久丁香花五月天色婷婷| 欧美亚洲中文字幕一区二区三区| 青青青青草手机在线视频免费看| 97香蕉碰碰人妻国产樱花| 亚洲综合乱码一区二区| 黄色资源视频网站日韩| 国产精品精品精品999| 风流唐伯虎电视剧在线观看| 岛国黄色大片在线观看| 午夜精品一区二区三区更新| 青青青青青青青青青青草青青 | 福利午夜视频在线合集| 日日摸夜夜添夜夜添毛片性色av| av在线观看网址av| 1024久久国产精品| 狠狠的往里顶撞h百合| 蜜桃色婷婷久久久福利在线| aaa久久久久久久久| 中文字幕一区的人妻欧美日韩| 任我爽精品视频在线播放| 天天射夜夜操综合网| 久草电影免费在线观看| 香蕉aⅴ一区二区三区| 欧美专区第八页一区在线播放| 国产va在线观看精品| 久久精品美女免费视频| 黄色成年网站午夜在线观看| 最后99天全集在线观看| 欧美老鸡巴日小嫩逼| 国产大鸡巴大鸡巴操小骚逼小骚逼| 久久久久久99国产精品| 韩国女主播精品视频网站| 97精品人妻一区二区三区精品| 全国亚洲男人的天堂| 97瑟瑟超碰在线香蕉| 熟女视频一区,二区,三区| 社区自拍揄拍尻屁你懂的| 亚洲午夜高清在线观看| 夜色17s精品人妻熟女| 午夜成午夜成年片在线观看| 日韩三级电影华丽的外出| www,久久久,com| 婷婷六月天中文字幕| 亚洲成av人无码不卡影片一| 国产视频在线视频播放| 免费黄高清无码国产| 91p0rny九色露脸熟女| 亚洲午夜高清在线观看| 久久久人妻一区二区| 98精产国品一二三产区区别| 美味人妻2在线播放| 福利视频网久久91| nagger可以指黑人吗| 2021天天色天天干| 欧美黄片精彩在线免费观看| 亚洲av男人的天堂你懂的| 日韩欧美亚洲熟女人妻| 日本三极片视频网站观看| 男女第一次视频在线观看| 一本一本久久a久久精品综合不卡| 一区二区三区日韩久久| 少妇系列一区二区三区视频| 国产欧美精品一区二区高清 | 国产高清精品极品美女| sspd152中文字幕在线| 国产熟妇乱妇熟色T区| 亚洲精品在线资源站| 青青草人人妻人人妻| 97青青青手机在线视频| 青青青青青青青青青国产精品视频| 中文字幕,亚洲人妻| 在线免费观看黄页视频| 日韩不卡中文在线视频网站| 老师啊太大了啊啊啊尻视频| 国产成人综合一区2区| 亚洲一区二区三区在线高清| 婷婷午夜国产精品久久久| 亚洲av黄色在线网站| 国产麻豆乱子伦午夜视频观看| 一区二区麻豆传媒黄片| 午夜久久久久久久精品熟女| 亚洲精品一区二区三区老狼| 被大鸡吧操的好舒服视频免费| 黄片色呦呦视频免费看| 99精品免费久久久久久久久a| 含骚鸡巴玩逼逼视频| 88成人免费av网站| 自拍偷拍日韩欧美一区二区| 99视频精品全部15| 色综合天天综合网国产成人| 成人伊人精品色xxxx视频| 久久午夜夜伦痒痒想咳嗽P| 国产精品久久久久网| 亚洲天堂有码中文字幕视频| 中文字幕无码日韩专区免费| 青青擦在线视频国产在线| 国产大学生援交正在播放| 成人区人妻精品一区二视频| 青青青视频自偷自拍38碰| 在线制服丝袜中文字幕| 精内国产乱码久久久久久| 任你操视频免费在线观看| 日韩人妻xxxxx| 激情伦理欧美日韩中文字幕| 精品91高清在线观看| 91自产国产精品视频| 自拍偷拍亚洲另类色图| 欧美精品黑人性xxxx| 和邻居少妇愉情中文字幕| 一区二区三区 自拍偷拍| 色伦色伦777国产精品| 后入美女人妻高清在线| 中文字幕乱码人妻电影| 天天日天天干天天爱| 亚洲粉嫩av一区二区三区| 天天操天天干天天插| 最新欧美一二三视频| 色噜噜噜噜18禁止观看| 久久久久久国产精品| 大黑人性xxxxbbbb| 亚洲第一黄色在线观看| 免费观看理论片完整版| 天天日天天摸天天爱| 美女骚逼日出水来了| 成熟丰满熟妇高潮xx×xx| 少妇与子乱在线观看| 国产又大又黄免费观看| 一区国内二区日韩三区欧美| 这里有精品成人国产99| 青青青青青青草国产| 真实国产乱子伦一区二区| 3D动漫精品啪啪一区二区下载 | 超碰97免费人妻麻豆| 欧洲国产成人精品91铁牛tv| 家庭女教师中文字幕在线播放| 好太好爽好想要免费| 亚洲精品在线资源站| 精品一区二区三区三区色爱| 青青在线视频性感少妇和隔壁黑丝 | 55夜色66夜色国产精品站| 2020av天堂网在线观看| 75国产综合在线视频| 欧美一区二区三区在线资源| 精品老妇女久久9g国产| 老司机午夜精品视频资源| 国产精品国产三级国产午| 日韩美女综合中文字幕pp| 美女被肏内射视频网站| 男人和女人激情视频| 亚洲男人的天堂a在线| 中文字幕一区二区自拍| 小泽玛利亚视频在线观看| 91 亚洲视频在线观看| 日本黄在免费看视频| 少妇高潮无套内谢麻豆| 亚洲欧美成人综合在线观看| 国产亚洲精品视频合集| 农村胖女人操逼视频| 色哟哟国产精品入口| av在线免费中文字幕| 午夜dv内射一区区| 毛片av在线免费看| 成人色综合中文字幕| 日韩a级精品一区二区| 热99re69精品8在线播放| 伊人网中文字幕在线视频| 国产精品人妻66p| 黑人性生活视频免费看| 国产亚洲视频在线观看| 2021天天色天天干| 久草视频在线一区二区三区资源站 | 国产清纯美女al在线| 免费男阳茎伸入女阳道视频| 亚洲无线观看国产高清在线| 人妻少妇精品久久久久久| 亚洲护士一区二区三区| 久久麻豆亚洲精品av| 阿v天堂2014 一区亚洲| 欧美偷拍自拍色图片| 亚洲午夜伦理视频在线| 国产性感美女福利视频| 日韩人妻在线视频免费| 青青青青草手机在线视频免费看| 欧美另类一区二区视频| 天天干天天日天天干天天操| 日韩在线中文字幕色| 日本一区美女福利视频| 午夜影院在线观看视频羞羞羞| 91免费放福利在线观看| 精品久久久久久久久久久a√国产| 国产一区二区火爆视频| 亚洲超碰97人人做人人爱| 最新国产亚洲精品中文在线| 色综合久久久久久久久中文| 宅男噜噜噜666国产| 久久三久久三久久三久久| 国产实拍勾搭女技师av在线| 国产日本精品久久久久久久| 欧美日韩激情啪啪啪| 瑟瑟视频在线观看免费视频| 97色视频在线观看| chinese国产盗摄一区二区| 激情国产小视频在线| 亚洲男人让女人爽的视频| 免费观看成年人视频在线观看| 中文乱理伦片在线观看| 精品亚洲中文字幕av| 日本熟妇一区二区x x| 年轻的人妻被夫上司侵犯| 亚洲熟女久久久36d| 亚洲精品乱码久久久本| 亚洲国产中文字幕啊啊啊不行了| 免费黄色成人午夜在线网站| 大尺度激情四射网站| 日韩欧美亚洲熟女人妻| 人人爽亚洲av人人爽av| 沙月文乃人妻侵犯中文字幕在线| 2021久久免费视频| av网站色偷偷婷婷网男人的天堂| 天天日天天天天天天天天天天| 亚洲天堂第一页中文字幕| 又粗又硬又猛又爽又黄的| 激情五月婷婷免费视频| 天堂女人av一区二区| 91人妻人人做人人爽在线| 亚洲精品福利网站图片| 天天插天天狠天天操| 91快播视频在线观看| 人妻少妇性色欲欧美日韩| 亚洲欧洲一区二区在线观看| 4个黑人操素人视频网站精品91 | 国内自拍第一页在线观看| 动色av一区二区三区| 欧洲精品第一页欧洲精品亚洲| 最新黄色av网站在线观看| 亚洲女人的天堂av| 鸡巴操逼一级黄色气| 热久久只有这里有精品| 国产又粗又猛又爽又黄的视频美国| 亚洲精品国产综合久久久久久久久 | 香港三日本三韩国三欧美三级| 午夜精品福利91av| 午夜精品亚洲精品五月色| 经典亚洲伊人第一页| 亚洲一级特黄特黄黄色录像片| 日韩人妻xxxxx| 亚洲中文字幕人妻一区| 成人免费毛片aaaa| 亚洲区欧美区另类最新章节| 九一传媒制片厂视频在线免费观看| lutube在线成人免费看| 丝袜肉丝一区二区三区四区在线看| 国产视频网站一区二区三区| 国产熟妇一区二区三区av| 天天色天天操天天舔| 免费啪啪啪在线观看视频| 综合一区二区三区蜜臀| 国产亚洲视频在线二区| 日韩无码国产精品强奸乱伦| 日日夜夜精品一二三| 久久久极品久久蜜桃| 人人妻人人爽人人澡人人精品| 人妻最新视频在线免费观看| 亚洲欧洲一区二区在线观看| 国产精品久久久久网| 97人妻夜夜爽二区欧美极品| 久久99久久99精品影院| 亚洲综合一区二区精品久久| 超污视频在线观看污污污| 亚洲一级特黄特黄黄色录像片| 91chinese在线视频| 9l人妻人人爽人人爽| 国产精品黄色的av| 久久久久久国产精品| av高潮迭起在线观看| 在线免费视频 自拍| 四川五十路熟女av| 欧洲黄页网免费观看| 超碰公开大香蕉97| 绝色少妇高潮3在线观看| 午夜激情精品福利视频| 精品久久婷婷免费视频| 亚洲欧美综合另类13p| 精品美女福利在线观看| 九色精品视频在线播放| 阴茎插到阴道里面的视频| 伊人成人在线综合网| 啪啪啪18禁一区二区三区 | 国产久久久精品毛片| 欧美地区一二三专区| 亚洲1卡2卡三卡4卡在线观看| 动漫精品视频在线观看| 视频久久久久久久人妻| 91国产在线视频免费观看| 女蜜桃臀紧身瑜伽裤 | 日本性感美女视频网站| 亚洲综合在线观看免费| 亚洲欧美久久久久久久久| 亚洲人人妻一区二区三区| 亚洲无码一区在线影院| 97人妻无码AV碰碰视频| 99热碰碰热精品a中文| 搞黄色在线免费观看| 一区二区在线观看少妇| 亚洲人妻视频在线网| 亚洲高清免费在线观看视频| 日本乱人一区二区三区| 人妻少妇精品久久久久久| 东游记中文字幕版哪里可以看到| 日本熟妇色熟妇在线观看| 亚国产成人精品久久久| 大香蕉大香蕉在线有码 av| 蜜桃专区一区二区在线观看| 青青擦在线视频国产在线| 喷水视频在线观看这里只有精品| 黄色片年轻人在线观看| 亚洲成人熟妇一区二区三区| 免费看美女脱光衣服的视频| 黄色成年网站午夜在线观看 | 日韩欧美中文国产在线| 亚洲欧美成人综合视频| 夜鲁夜鲁狠鲁天天在线| 亚洲av色图18p| xxx日本hd高清| 日本男女操逼视频免费看| 97精品成人一区二区三区 | av中文字幕电影在线看| 可以免费看的www视频你懂的| 午夜毛片不卡免费观看视频| 91色网站免费在线观看| 91精品综合久久久久3d动漫| 中文乱理伦片在线观看| 青青青激情在线观看视频| 欧美久久一区二区伊人| tube69日本少妇| 一级黄色av在线观看| 中文字幕一区二区亚洲一区| 成熟熟女国产精品一区| 国产普通话插插视频| 又色又爽又黄的美女裸体| 亚洲午夜电影之麻豆| 深田咏美亚洲一区二区| 国产日本欧美亚洲精品视| 日韩写真福利视频在线观看| 免费成人va在线观看| 国产视频一区二区午夜| 五月天色婷婷在线观看视频免费| 天天射夜夜操狠狠干| 天天爽夜夜爽人人爽QC| 精品老妇女久久9g国产| 中文字幕av第1页中文字幕| 十八禁在线观看地址免费| 亚洲粉嫩av一区二区三区| 大白屁股精品视频国产| 91中文字幕免费在线观看| 一级黄片久久久久久久久| av手机免费在线观看高潮| 欧美激情精品在线观看| 午夜精品九一唐人麻豆嫩草成人| 亚洲熟妇久久无码精品| 经典亚洲伊人第一页| 国产一区自拍黄视频免费观看 | 免费无码人妻日韩精品一区二区 | 青青擦在线视频国产在线| 免费成人av中文字幕| av完全免费在线观看av| 一区二区三区蜜臀在线| 大香蕉福利在线观看| 中文字幕成人日韩欧美| 黄色三级网站免费下载| 爱有来生高清在线中文字幕| 91欧美在线免费观看| 可以在线观看的av中文字幕| 一区二区三区美女毛片| 自拍偷拍,中文字幕| 欧洲日韩亚洲一区二区三区| 丁香花免费在线观看中文字幕| 性生活第二下硬不起来| 欧美日韩亚洲国产无线码| 91人妻精品一区二区在线看| 欧美黑人与人妻精品| 亚洲久久午夜av一区二区| 99精品国产aⅴ在线观看| 日韩三级黄色片网站| 四虎永久在线精品免费区二区| 青青社区2国产视频| 日本成人不卡一区二区| 韩国AV无码不卡在线播放| 爱有来生高清在线中文字幕| 91久久国产成人免费网站| 传媒在线播放国产精品一区| 人妻av无码专区久久绿巨人| 四川乱子伦视频国产vip| 免费观看国产综合视频| 毛片一级完整版免费| 啊啊啊想要被插进去视频| 粉嫩av蜜乳av蜜臀| 欧美亚洲一二三区蜜臀| 午夜精品福利91av| 一区二区三区的久久的蜜桃的视频| 少妇人妻100系列| 揄拍成人国产精品免费看视频| 夜女神免费福利视频| 97超碰国语国产97超碰| 久久www免费人成一看片| 国产精品国产三级国产午| 91快播视频在线观看| 亚洲 色图 偷拍 欧美| 黄色无码鸡吧操逼视频| 国产男女视频在线播放| 亚洲 欧美 精品 激情 偷拍 | 黄色视频在线观看高清无码| 午夜精品福利一区二区三区p| 男人的网址你懂的亚洲欧洲av| 一区二区麻豆传媒黄片 | 高潮喷水在线视频观看| 午夜大尺度无码福利视频| 2018在线福利视频| 国产精品3p和黑人大战| 亚洲午夜高清在线观看| 女生自摸在线观看一区二区三区| 久久精品国产999| 午夜免费观看精品视频| 国产亚洲精品视频合集| av高潮迭起在线观看| 又色又爽又黄的美女裸体| 最近中文字幕国产在线| 性色蜜臀av一区二区三区| 欧美日韩v中文在线| 中文字幕国产专区欧美激情| 欧亚日韩一区二区三区观看视频| 大香蕉伊人中文字幕| 91国产资源在线视频| 国产亚洲天堂天天一区| 国产91嫩草久久成人在线视频| 在线免费观看99视频| 人妻少妇亚洲一区二区| 家庭女教师中文字幕在线播放| 欧美专区第八页一区在线播放| 亚洲激情,偷拍视频| 黄色视频成年人免费观看| 最新91九色国产在线观看| 9国产精品久久久久老师| 国产性感美女福利视频| 丝袜美腿欧美另类 中文字幕| 日韩三级黄色片网站| 欧美va不卡视频在线观看 | 国产不卡av在线免费| 老有所依在线观看完整版| 绯色av蜜臀vs少妇| 国产成人一区二区三区电影网站| 不卡一区一区三区在线| 55夜色66夜色国产精品站| 18禁美女羞羞免费网站| 日韩欧美国产一区ab| 大香蕉日本伊人中文在线| 欧美精品国产综合久久| 1区2区3区4区视频在线观看| 黄色在线观看免费观看在线| 免费在线福利小视频| 91中文字幕最新合集| 综合一区二区三区蜜臀| 亚洲成人av在线一区二区| 桃色视频在线观看一区二区| 国产精品入口麻豆啊啊啊| 黄色资源视频网站日韩| 中文字幕—97超碰网| 精品少妇一二三视频在线| 欲乱人妻少妇在线视频裸| 91精品国产黑色丝袜| 午夜免费体验区在线观看| 午夜极品美女福利视频| 自拍偷拍,中文字幕| 日本一二三区不卡无| 91久久综合男人天堂| 中文字幕1卡1区2区3区| 欧美特色aaa大片| 91精品视频在线观看免费| 亚洲免费国产在线日韩| 国产高清97在线观看视频| 内射久久久久综合网| 免费一级特黄特色大片在线观看 | 亚洲免费va在线播放| 伊人开心婷婷国产av| 大香蕉伊人国产在线| 搡老熟女一区二区在线观看| 含骚鸡巴玩逼逼视频| 日韩精品啪啪视频一道免费| 99re国产在线精品| 亚洲男人的天堂a在线| 香蕉av影视在线观看| 伊人精品福利综合导航| 久久精品美女免费视频| 麻豆性色视频在线观看| 成熟熟女国产精品一区| 日本一本午夜在线播放| 1区2区3区4区视频在线观看| 亚洲青青操骚货在线视频| 大陆精品一区二区三区久久| 国产中文字幕四区在线观看| 欧美成人精品在线观看| 欧美一级色视频美日韩| 大屁股肉感人妻中文字幕在线| 久久久久只精品国产三级| 亚洲国产精品中文字幕网站| 欧美一区二区三区激情啪啪啪 | 午夜成午夜成年片在线观看| 少妇人妻100系列| 99国产精品窥熟女精品| 天天日天天鲁天天操| 精品国产午夜视频一区二区| 日噜噜噜夜夜噜噜噜天天噜噜噜| 亚洲av琪琪男人的天堂| 色噜噜噜噜18禁止观看| 2025年人妻中文字幕乱码在线| 日日操综合成人av| 97人妻无码AV碰碰视频| 成人国产激情自拍三区| 精品亚洲在线免费观看| 成人区人妻精品一区二视频| 岛国av高清在线成人在线| 天天日天天干天天爱| 天天躁夜夜躁日日躁a麻豆| 亚洲码av无色中文| 瑟瑟视频在线观看免费视频| 亚洲欧美久久久久久久久| 四川乱子伦视频国产vip| 偷拍自拍 中文字幕| 中文字幕日韩精品就在这里| 97成人免费在线观看网站| 国产va精品免费观看 | 4个黑人操素人视频网站精品91| 人妻少妇一区二区三区蜜桃| 同居了嫂子在线播高清中文| 91国语爽死我了不卡| 精品美女在线观看视频在线观看| 亚洲精品无码久久久久不卡| 97国产在线av精品| 欧美在线精品一区二区三区视频| 沈阳熟妇28厘米大战黑人| 国产露脸对白在线观看| 在线观看日韩激情视频| 在线免费观看国产精品黄色| 经典亚洲伊人第一页| av网址在线播放大全| 91香蕉成人app下载| 啊用力插好舒服视频| 国产自拍在线观看成人| 99国产精品窥熟女精品| 在线 中文字幕 一区| 扒开腿挺进肉嫩小18禁视频| 日韩精品二区一区久久| 国产成人自拍视频播放| 激情人妻校园春色亚洲欧美| 91极品大一女神正在播放| 毛片av在线免费看| 青娱乐极品视频青青草| 99国内小视频在现欢看| 大胸性感美女羞爽操逼毛片| 51国产成人精品视频| 高潮视频在线快速观看国家快速| 免费在线播放a级片| 国产精品国色综合久久| 色天天天天射天天舔| 亚洲人成精品久久久久久久| 九色porny九色9l自拍视频| 免费黄色成人午夜在线网站| 精品亚洲国产中文自在线| 亚洲午夜在线视频福利| 99久久中文字幕一本人| 亚洲欧美清纯唯美另类| 日本少妇在线视频大香蕉在线观看 | 日韩精品二区一区久久| 毛茸茸的大外阴中国视频| 99精品国自产在线人| 扒开腿挺进肉嫩小18禁视频| 天天日天天干天天舔天天射| 欧美80老妇人性视频| 蜜桃视频入口久久久| 天天射夜夜操狠狠干| 2020国产在线不卡视频| 熟女人妻在线观看视频| 一二三区在线观看视频| 国产亚洲视频在线二区| 大香蕉玖玖一区2区| 亚洲一区二区三区av网站| 夜色撩人久久7777| 97精品人妻一区二区三区精品| 99久久久无码国产精品性出奶水| 伊人成人在线综合网| 在线观看视频 你懂的| 自拍偷拍vs一区二区三区| 国产使劲操在线播放| 午夜精品九一唐人麻豆嫩草成人| 日韩成人免费电影二区| 瑟瑟视频在线观看免费视频| 亚洲激情唯美亚洲激情图片| 岛国毛片视频免费在线观看| 91国产在线视频免费观看| 亚洲av成人免费网站| 国产精品免费不卡av| 天天射夜夜操狠狠干| 亚洲精品国品乱码久久久久| 动漫精品视频在线观看| 亚洲一区二区三区精品乱码| 国产高清在线观看1区2区| 一色桃子久久精品亚洲| 午夜美女少妇福利视频| 国产夫妻视频在线观看免费| 欧美视频不卡一区四区| 免费看国产又粗又猛又爽又黄视频| 不卡日韩av在线观看| 国产麻豆精品人妻av| 国产精品一区二区三区蜜臀av| 丝袜肉丝一区二区三区四区在线看| 宅男噜噜噜666免费观看| 91大屁股国产一区二区| 国产精品人妻66p| 91欧美在线免费观看| 在线网站你懂得老司机| 青青青青青青青青青青草青青| 999热精品视频在线| 亚洲福利精品福利精品福利| 色秀欧美视频第一页| 91天堂精品一区二区| 大陆av手机在线观看| 99亚洲美女一区二区三区| 国产实拍勾搭女技师av在线| 又粗又硬又猛又爽又黄的| 日韩欧美国产一区不卡| 啪啪啪18禁一区二区三区| 日韩a级黄色小视频| 久久丁香花五月天色婷婷| 99热碰碰热精品a中文| 92福利视频午夜1000看| 清纯美女在线观看国产| 国产成人精品久久二区91| 欧美日本aⅴ免费视频| 国产真实乱子伦a视频| 亚洲精品福利网站图片| 久久综合老鸭窝色综合久久| 东京热男人的av天堂| 99热这里只有精品中文| 丝袜美腿视频诱惑亚洲无 | 精品久久久久久高潮| 特一级特级黄色网片| 国产刺激激情美女网站| 经典av尤物一区二区| 青青青国产免费视频| 亚洲一级 片内射视正片| 亚洲av色香蕉一区二区三区| 日本真人性生活视频免费看| 最新日韩av传媒在线| 在线免费观看国产精品黄色| 亚洲成高清a人片在线观看| 全国亚洲男人的天堂| 人妻熟女在线一区二区| 97成人免费在线观看网站| 亚洲精品成人网久久久久久小说| 国产又粗又硬又大视频| 黄色资源视频网站日韩| 2017亚洲男人天堂| 日本人妻欲求不满中文字幕| 欧美日韩激情啪啪啪| 边摸边做超爽毛片18禁色戒| 大陆精品一区二区三区久久| 最近中文字幕国产在线| 久久美欧人妻少妇一区二区三区| 欧美精品国产综合久久| 亚洲精品色在线观看视频| 日韩av有码中文字幕| 久久农村老妇乱69系列| 天天干夜夜操天天舔| 一区二区视频在线观看视频在线| 天天做天天干天天操天天射| 成人色综合中文字幕| 超碰在线中文字幕一区二区| 久草视频在线一区二区三区资源站 | 欧美成人小视频在线免费看| av中文字幕国产在线观看| 11久久久久久久久久久| 91片黄在线观看喷潮| 少妇人妻100系列| 午夜福利资源综合激情午夜福利资| 日韩av有码中文字幕| 日本精品美女在线观看| 毛茸茸的大外阴中国视频| 农村胖女人操逼视频| 日本性感美女视频网站| 国产精品国产精品一区二区| 亚洲综合另类欧美久久| 粉嫩av蜜乳av蜜臀| 大胸性感美女羞爽操逼毛片| nagger可以指黑人吗| 91国语爽死我了不卡| 日本又色又爽又黄又粗| 国产97视频在线精品| 99精品视频之69精品视频| 亚洲欧美另类手机在线| 宅男噜噜噜666国产| 午夜精品久久久久久99热| 自拍偷区二区三区麻豆| 午夜精品一区二区三区4| 青青擦在线视频国产在线| 日本男女操逼视频免费看| 国产白袜脚足J棉袜在线观看| 亚洲另类伦春色综合小| 亚洲高清视频在线不卡| 99热国产精品666| 小穴多水久久精品免费看| 国产成人自拍视频在线免费观看| 亚洲成人激情av在线| 亚洲中文字幕国产日韩| 18禁无翼鸟成人在线| 色婷婷综合激情五月免费观看| 亚洲1069综合男同| 国产成人精品一区在线观看| 国产大鸡巴大鸡巴操小骚逼小骚逼 | 无忧传媒在线观看视频| 日本高清撒尿pissing| 欧美日本国产自视大全| 老有所依在线观看完整版 | 色哟哟在线网站入口| 国产精品久久久久久久女人18| 国产va在线观看精品| 欧美亚洲免费视频观看| 99精品免费观看视频| 日本少妇精品免费视频| 国产极品精品免费视频| 亚洲高清视频在线不卡| 国产精品视频男人的天堂| 国产麻豆乱子伦午夜视频观看| 色综合天天综合网国产成人| 中文亚洲欧美日韩无线码| 亚洲无线观看国产高清在线| 中文字幕乱码人妻电影| 一本久久精品一区二区| 亚洲人妻30pwc| 国产va在线观看精品| 天天日天天爽天天干| 啪啪啪操人视频在线播放| 亚洲欧美另类自拍偷拍色图| 黄色三级网站免费下载| 天天干天天操天天爽天天摸| 一区二区三区麻豆福利视频| av在线免费观看亚洲天堂| 日本性感美女写真视频| 国产视频网站一区二区三区 | 红杏久久av人妻一区| 水蜜桃国产一区二区三区| 国产女孩喷水在线观看| 一区二区三区国产精选在线播放| 在线新三级黄伊人网| 少妇被强干到高潮视频在线观看| 五十路丰满人妻熟妇| 亚洲精品午夜久久久久| 特大黑人巨大xxxx| 亚洲蜜臀av一区二区三区九色| 亚洲图片欧美校园春色| 视频久久久久久久人妻| 欧美一级视频一区二区| 亚洲区欧美区另类最新章节| 亚洲国产第一页在线观看| 久久久噜噜噜久久熟女av| 老熟妇凹凸淫老妇女av在线观看| 天天日天天干天天要| 精品国产在线手机在线| 91综合久久亚洲综合| 丝袜亚洲另类欧美变态| 日本精品一区二区三区在线视频。 | 亚洲图库另类图片区| 精品suv一区二区69| 青春草视频在线免费播放| 久久一区二区三区人妻欧美| 99精品视频在线观看免费播放| 欧美综合婷婷欧美综合| 久久丁香花五月天色婷婷| 亚洲av无码成人精品区辽| 久草视频福利在线首页| 日本熟妇色熟妇在线观看| 欧美一级片免费在线成人观看| 亚洲中文字幕乱码区| 日本高清在线不卡一区二区| 日本熟女精品一区二区三区| 亚洲综合乱码一区二区| sw137 中文字幕 在线| 999热精品视频在线| 大鸡巴操娇小玲珑的女孩逼| 午夜久久久久久久99| 日本av熟女在线视频| 亚洲va天堂va国产va久| 国产又色又刺激在线视频| 换爱交换乱高清大片| 国产97在线视频观看| 懂色av之国产精品| 又粗又硬又猛又爽又黄的| 免费观看成年人视频在线观看| 少妇人妻100系列| 91精品资源免费观看| 97a片免费在线观看| 日韩中文字幕精品淫| 日本av在线一区二区三区| 日本五十路熟新垣里子| 国产亚洲欧美另类在线观看| 亚洲欧美色一区二区| 免费在线观看污污视频网站| 免费观看理论片完整版| 老司机午夜精品视频资源| 66久久久久久久久久久| 中文字幕乱码av资源| 午夜频道成人在线91| 女同性ⅹxx女同h偷拍| 日本熟妇一区二区x x| 日韩a级精品一区二区| 欧美日韩一区二区电影在线观看| 又粗又硬又猛又黄免费30| 人妻少妇精品久久久久久| 亚洲精品成人网久久久久久小说| 美女被肏内射视频网站| 在线视频这里只有精品自拍| 亚洲第一黄色在线观看| 一区二区三区久久中文字幕| 538精品在线观看视频| 亚洲av色图18p| 护士特殊服务久久久久久久| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 99热久久这里只有精品8| 懂色av之国产精品| 制丝袜业一区二区三区| 人妻久久久精品69系列| 欧美另类一区二区视频| 日本韩国在线观看一区二区| 成人蜜桃美臀九一一区二区三区| 天堂av中文在线最新版| 三级等保密码要求条款| 51精品视频免费在线观看| 久久午夜夜伦痒痒想咳嗽P| 亚洲综合自拍视频一区| 中文字幕成人日韩欧美| 孕妇奶水仑乱A级毛片免费看| 在线不卡日韩视频播放| 在线网站你懂得老司机| 亚洲国际青青操综合网站| 日韩二区视频一线天婷婷五| 久久久精品国产亚洲AV一| 99热国产精品666| 国产一区二区火爆视频| 一区二区三区另类在线| 日韩av中文在线免费观看| 欧美特色aaa大片| 亚洲欧美综合另类13p| 午夜免费体验区在线观看| 久久久久久久久久久免费女人| 国产在线拍揄自揄视频网站| 久久精品视频一区二区三区四区| 国产精品手机在线看片| 2o22av在线视频| 啊啊好大好爽啊啊操我啊啊视频| 亚洲乱码中文字幕在线| 久久久久91精品推荐99| 红桃av成人在线观看| 青青热久免费精品视频在线观看| 男人天堂av天天操| 久草视频在线看免费| 亚洲人妻视频在线网| 亚洲变态另类色图天堂网| 欧美xxx成人在线| 不卡精品视频在线观看| 啊用力插好舒服视频| 日本熟妇丰满厨房55| 亚洲一区二区三区久久午夜| 亚洲欧美色一区二区| 亚洲欧美激情国产综合久久久| av老司机精品在线观看| 97少妇精品在线观看| 亚洲成人三级在线播放| 国产一线二线三线的区别在哪| 大鸡巴插入美女黑黑的阴毛| 一级黄色av在线观看| 青青青激情在线观看视频| 人人妻人人人操人人人爽| 欧美美女人体视频一区| v888av在线观看视频| 日本午夜久久女同精女女| 精品老妇女久久9g国产| 国产三级片久久久久久久| 午夜精品在线视频一区| 综合一区二区三区蜜臀| 一区二区三区四区五区性感视频| 国产美女午夜福利久久| 欧美特色aaa大片| 动漫av网站18禁| 天天色天天舔天天射天天爽| 久久久久久久久久久久久97| 蜜桃色婷婷久久久福利在线| 日韩少妇人妻精品无码专区| 青青青青青青青在线播放视频| 久久艹在线观看视频| 国产清纯美女al在线| 一区二区三区日韩久久| 日韩黄色片在线观看网站| 狠狠操操操操操操操操操| 国产高潮无码喷水AV片在线观看| 国产精品成人xxxx| 97人妻夜夜爽二区欧美极品| 亚洲av色图18p| 精品av国产一区二区三区四区 | 久久久久久久久久久久久97| 欧美偷拍亚洲一区二区| av无限看熟女人妻另类av| 日韩成人综艺在线播放| 欧美视频一区免费在线| 粉嫩av蜜乳av蜜臀| 亚洲精品av在线观看| 国产高清97在线观看视频| 九一传媒制片厂视频在线免费观看| 91av中文视频在线| av在线免费观看亚洲天堂| 97超碰人人搞人人| 亚洲av黄色在线网站| 婷婷五月亚洲综合在线| av日韩在线免费播放| 中文字幕在线观看国产片| 国产视频精品资源网站| free性日本少妇| 在线观看视频网站麻豆| 一区二区三区精品日本| 天天干天天操天天摸天天射| 亚洲天堂有码中文字幕视频| 男人天堂最新地址av| 九九热99视频在线观看97| 可以在线观看的av中文字幕| 又粗又硬又猛又爽又黄的| 91九色porny蝌蚪国产成人| 久久久久久九九99精品| 亚洲天堂有码中文字幕视频| 黑人性生活视频免费看| 视频二区在线视频观看| 日韩欧美亚洲熟女人妻| v888av在线观看视频| 初美沙希中文字幕在线| 久久亚洲天堂中文对白| 第一福利视频在线观看| 成人av久久精品一区二区| 中文字幕在线乱码一区二区 | 天天干夜夜操天天舔| av中文字幕福利网| 91精品国产麻豆国产| 黄色视频在线观看高清无码| 免费高清自慰一区二区三区网站| 自拍偷拍一区二区三区图片| 国产真实灌醉下药美女av福利| 97人妻人人澡爽人人精品| 国产一区二区视频观看| 美女吃鸡巴操逼高潮视频| 国产 在线 免费 精品| 视频在线亚洲一区二区| 国产三级精品三级在线不卡| 777奇米久久精品一区| 日韩熟女系列一区二区三区| 91chinese在线视频| 快点插进来操我逼啊视频| 亚洲推理片免费看网站| 无码日韩人妻精品久久| 免费在线看的黄网站| 国产精品手机在线看片| 男女之间激情网午夜在线| 免费在线观看污污视频网站| av一区二区三区人妻| 香蕉91一区二区三区| 男女第一次视频在线观看| 中文字幕免费福利视频6| 91久久精品色伊人6882| 中文字幕最新久久久| 91综合久久亚洲综合| 超级福利视频在线观看| 亚洲欧美激情国产综合久久久| 东京热男人的av天堂| 亚洲成高清a人片在线观看| 在线观看免费岛国av| 中文字幕在线一区精品| 色综合天天综合网国产成人| 亚洲一级av无码一级久久精品| 大香蕉福利在线观看| 久久丁香花五月天色婷婷| 国产成人精品av网站| 色狠狠av线不卡香蕉一区二区| 亚洲免费视频欧洲免费视频| 青青青视频手机在线观看| 激情小视频国产在线| 欧美成人一二三在线网| 在线成人日韩av电影| 国产美女午夜福利久久| 日本真人性生活视频免费看| 日本特级片中文字幕| 天天干天天插天天谢| 亚洲国产免费av一区二区三区 | 丰满的子国产在线观看| 毛茸茸的大外阴中国视频| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲另类在线免费观看| 国产日韩av一区二区在线| av在线免费资源站| 日韩人妻在线视频免费| 国产麻豆91在线视频| 韩国AV无码不卡在线播放| 国产性生活中老年人视频网站| 大胆亚洲av日韩av| 端庄人妻堕落挣扎沉沦| 国产揄拍高清国内精品对白| 制服丝袜在线人妻中文字幕| 偷拍自拍亚洲美腿丝袜| 国产福利在线视频一区| av在线观看网址av| 天堂av中文在线最新版| 麻豆性色视频在线观看| 一区二区三区四区中文| 国产精品一区二区久久久av| 国产麻豆乱子伦午夜视频观看| 少妇一区二区三区久久久| 沈阳熟妇28厘米大战黑人| 99av国产精品欲麻豆| 天天日天天摸天天爱| 少妇露脸深喉口爆吞精| 午夜国产福利在线观看| 91p0rny九色露脸熟女| 亚洲 欧美 精品 激情 偷拍| 亚洲av无乱一区二区三区性色| 免费十精品十国产网站| 激情综合治理六月婷婷| 国产刺激激情美女网站| 色伦色伦777国产精品| 特大黑人巨大xxxx| 欧美地区一二三专区| 美女在线观看日本亚洲一区| 美女福利视频导航网站| 青青热久免费精品视频在线观看 | 免费69视频在线看| 丝袜国产专区在线观看| 日韩av免费观看一区| 日韩av免费观看一区| 最近中文字幕国产在线| 日曰摸日日碰夜夜爽歪歪| 国产第一美女一区二区三区四区| 热99re69精品8在线播放| 含骚鸡巴玩逼逼视频| 玖玖一区二区在线观看| 国产精品国产三级麻豆| 国产精品中文av在线播放| 日韩精品激情在线观看| 青青草原色片网站在线观看| 亚洲成人免费看电影| 亚洲 欧美 自拍 偷拍 在线| 国产精品自拍偷拍a| 欧美成人精品欧美一级黄色| 极品性荡少妇一区二区色欲| 青青青青青青草国产| 成年人午夜黄片视频资源| 99精品国产自在现线观看| 在线国产中文字幕视频| 性生活第二下硬不起来| 成人网18免费视频版国产| 蜜臀成人av在线播放| 免费69视频在线看| 91精品国产观看免费| 精品视频国产在线观看| 中文字幕在线永久免费播放| 国产精品中文av在线播放| 啪啪啪18禁一区二区三区| 日韩亚国产欧美三级涩爱| 天天夜天天日天天日| 国产日韩精品免费在线| 免费在线观看视频啪啪| 亚洲一区制服丝袜美腿| 91九色porny蝌蚪国产成人| 女同互舔一区二区三区| 天天草天天色天天干| 福利一二三在线视频观看| 日本黄在免费看视频| 99热久久这里只有精品8| 免费在线黄色观看网站| 熟女人妻一区二区精品视频| 成熟丰满熟妇高潮xx×xx| 成年人黄色片免费网站| 在线制服丝袜中文字幕| 大学生A级毛片免费视频| 一区二区三区蜜臀在线| 青青草视频手机免费在线观看| av大全在线播放免费| 国产精品成人xxxx| 在线观看av2025| 欧亚乱色一区二区三区| 日韩无码国产精品强奸乱伦| 80电影天堂网官网| 国产日韩欧美美利坚蜜臀懂色| 亚洲天堂第一页中文字幕| 国产在线一区二区三区麻酥酥| 大香蕉伊人国产在线| 日韩少妇人妻精品无码专区| 精品人人人妻人人玩日产欧| 欧美精品资源在线观看| 国产无遮挡裸体免费直播视频| 天天日天天添天天爽| 亚国产成人精品久久久| 国产变态另类在线观看| 午夜久久香蕉电影网| 国产一区二区久久久裸臀| 国产精品中文av在线播放 | 国产揄拍高清国内精品对白| 一区国内二区日韩三区欧美| 中文字幕免费福利视频6| 91精品国产观看免费| 抽查舔水白紧大视频| 天堂女人av一区二区| 亚洲 色图 偷拍 欧美| av高潮迭起在线观看| 天天日天天透天天操| 国产欧美精品一区二区高清| 国产日韩欧美视频在线导航| 免费在线黄色观看网站| 在线播放一区二区三区Av无码| 一级黄色av在线观看| 亚洲 中文 自拍 另类 欧美| 久久久久久国产精品| 91高清成人在线视频| 天天摸天天日天天操| 狠狠鲁狠狠操天天晚上干干| 国产美女精品福利在线| 国产成人精品福利短视频| 2022中文字幕在线| 午夜免费观看精品视频| 热思思国产99re| 99热国产精品666| 免费在线黄色观看网站| 动漫黑丝美女的鸡巴| 在线新三级黄伊人网| 偷青青国产精品青青在线观看| 亚洲高清自偷揄拍自拍| 91精品激情五月婷婷在线| 初美沙希中文字幕在线 | 91亚洲精品干熟女蜜桃频道| 久久三久久三久久三久久| 午夜婷婷在线观看视频| 亚洲欧美综合在线探花| 免费在线黄色观看网站| 自拍偷拍 国产资源| 日本一区二区三区免费小视频| 熟女人妻一区二区精品视频| 美女福利视频导航网站| 夜女神免费福利视频| 国产在线拍揄自揄视频网站| 亚洲区美熟妇久久久久| 3344免费偷拍视频| 老司机福利精品免费视频一区二区 | 亚洲国产在线精品国偷产拍| 中国熟女一区二区性xx| 91国偷自产一区二区三区精品| 99久久99久国产黄毛片| 熟女人妻在线中出观看完整版| 啊啊啊视频试看人妻| 天天摸天天日天天操| 国产精品人妻66p| 宅男噜噜噜666免费观看| 99精品视频之69精品视频| 91精品啪在线免费| 92福利视频午夜1000看| 少妇与子乱在线观看| 欧美美女人体视频一区| 2018在线福利视频| 最后99天全集在线观看| 亚洲狠狠婷婷综合久久app| 欧美黄色录像免费看的| 精品一区二区三区三区色爱| 又黄又刺激的午夜小视频| 国产精品一区二区av国| 青青青青青青青青青青草青青| 国产aⅴ一线在线观看| 91久久精品色伊人6882| 51国产偷自视频在线播放| 超碰中文字幕免费观看| 日韩三级黄色片网站| 91快播视频在线观看| 天天干天天啪天天舔| 国产成人精品一区在线观看 | 1000部国产精品成人观看视频| 少妇人妻100系列| 色婷婷综合激情五月免费观看 | 久草电影免费在线观看| 欧洲欧美日韩国产在线| 色哟哟在线网站入口| 天天射,天天操,天天说| 欧美亚洲中文字幕一区二区三区| 久久久人妻一区二区| 99久久99久国产黄毛片| 不卡精品视频在线观看| 亚洲精品国产综合久久久久久久久| 狠狠鲁狠狠操天天晚上干干| 欧美男人大鸡吧插女人视频| 75国产综合在线视频| 亚洲天堂精品久久久| 午夜成午夜成年片在线观看| 一区二区三区麻豆福利视频| 精彩视频99免费在线| 91九色国产熟女一区二区| 欧美亚洲牲夜夜综合久久| 一区二区三区精品日本| av新中文天堂在线网址| 99精品国产自在现线观看| 久草极品美女视频在线观看| 国产黑丝高跟鞋视频在线播放| 亚洲成人情色电影在线观看| 老司机福利精品视频在线| 爱爱免费在线观看视频| 亚洲欧美精品综合图片小说| 岛国免费大片在线观看| 福利视频广场一区二区| 国产精品福利小视频a| 男生舔女生逼逼视频| 91一区精品在线观看| 91精品综合久久久久3d动漫| 亚洲粉嫩av一区二区三区| 亚洲va国产va欧美精品88| jul—619中文字幕在线| 在线观看黄色成年人网站| 亚洲一区av中文字幕在线观看| 国产亚州色婷婷久久99精品| 黄色资源视频网站日韩| 小穴多水久久精品免费看| 亚洲免费国产在线日韩| 天天色天天操天天舔| 久久久久久久久久久免费女人| 99热这里只有国产精品6| 视频一区二区在线免费播放| 在线免费观看亚洲精品电影| 在线不卡成人黄色精品| 中国黄色av一级片| 亚洲天堂精品福利成人av| 欧美特级特黄a大片免费| 日本av熟女在线视频| 免费成人va在线观看| 黄色av网站免费在线| 2017亚洲男人天堂| 亚洲欧美一区二区三区电影| 欧美一区二区三区啪啪同性| 超黄超污网站在线观看| 9国产精品久久久久老师| 大胸性感美女羞爽操逼毛片| 日韩无码国产精品强奸乱伦| 和邻居少妇愉情中文字幕| 晚上一个人看操B片| 男人的天堂一区二区在线观看| 三级黄色亚洲成人av| 偷拍自拍福利视频在线观看| 天天干夜夜操啊啊啊| 沙月文乃人妻侵犯中文字幕在线| 亚洲欧美清纯唯美另类 | 亚洲成人av一区在线| 天天射夜夜操综合网| 一区二区在线观看少妇| 亚洲精品在线资源站| 天天综合天天综合天天网| av天堂中文免费在线| 久久丁香婷婷六月天| 最新欧美一二三视频| 香蕉片在线观看av| 97青青青手机在线视频| 啊慢点鸡巴太大了啊舒服视频| 欧美一级色视频美日韩| 久久免费看少妇高潮完整版| 中文字幕人妻av在线观看| 大香蕉福利在线观看| 视频一区 二区 三区 综合| 国产精品国产精品一区二区| 欧美成人综合视频一区二区| 青青青青视频在线播放| 91国内精品自线在拍白富美| 国产麻豆剧果冻传媒app| 久久精品亚洲成在人线a| 青娱乐在线免费视频盛宴| 男人天堂av天天操| 不戴胸罩引我诱的隔壁的人妻| 欧美另类重口味极品在线观看| 青娱乐极品视频青青草| 五十路息与子猛烈交尾视频 | 18禁无翼鸟成人在线| 欧美黄色录像免费看的| 中国熟女@视频91| 动漫黑丝美女的鸡巴| 日韩视频一区二区免费观看| 青青色国产视频在线| 中文字幕高清免费在线人妻| 黄色成年网站午夜在线观看 | 天天操天天插天天色| 国产超码片内射在线| 淫秽激情视频免费观看| 免费看国产av网站| 懂色av之国产精品| 亚洲 清纯 国产com| 黄色片一级美女黄色片| 国产精品国产三级国产精东| 日韩人妻丝袜中文字幕| 欧美精品中文字幕久久二区| 青青青青视频在线播放| 国产成人自拍视频播放| 久久久久久久久久性潮| 国产精彩对白一区二区三区| 国产黄色高清资源在线免费观看| 久久久久久九九99精品| 中文字幕高清免费在线人妻| 国产日韩精品电影7777| 在线观看一区二区三级| 亚洲激情,偷拍视频| 欧美精产国品一二三产品区别大吗| 任你操视频免费在线观看| 3337p日本欧洲大胆色噜噜| 久久香蕉国产免费天天| 91国产在线免费播放| 国产高清女主播在线| 任你操任你干精品在线视频| 国产精品国产三级麻豆| 亚洲推理片免费看网站| 青青社区2国产视频| 午夜久久香蕉电影网| 亚洲国产第一页在线观看| 国产一级精品综合av| 成年人黄色片免费网站| 视频一区二区在线免费播放 | 欧美成人一二三在线网| 久碰精品少妇中文字幕av| 成人影片高清在线观看| 国产揄拍高清国内精品对白| 亚洲中文字幕乱码区| 美味人妻2在线播放| 88成人免费av网站| 888欧美视频在线| eeuss鲁片一区二区三区| 午夜激情精品福利视频| 美女少妇亚洲精选av| 国产精品福利小视频a| 日本美女成人在线视频| 最新日韩av传媒在线| 999九九久久久精品| 69精品视频一区二区在线观看| 91亚洲精品干熟女蜜桃频道| 日曰摸日日碰夜夜爽歪歪| 精品久久久久久久久久久久人妻| 国产午夜亚洲精品不卡在线观看| 成年午夜影片国产片| 亚洲国产中文字幕啊啊啊不行了| 色吉吉影音天天干天天操| 青青操免费日综合视频观看| 在线观看免费av网址大全| 久久人人做人人妻人人玩精品vr| 白白操白白色在线免费视频| 黄页网视频在线免费观看| 日韩写真福利视频在线观看| 在线观看av观看av| 男人天堂最新地址av| 深夜男人福利在线观看| 最新中文字幕乱码在线| 成年人该看的视频黄免费| 欧美亚洲中文字幕一区二区三区| 这里只有精品双飞在线播放| 大陆精品一区二区三区久久| 红桃av成人在线观看| 91亚洲国产成人精品性色| 色97视频在线播放| 欧美亚洲一二三区蜜臀| 欧美视频一区免费在线| 视频 一区二区在线观看| 夜色撩人久久7777| 国产妇女自拍区在线观看| 黄片三级三级三级在线观看| 91免费黄片可看视频| 天天做天天干天天操天天射| 在线观看国产网站资源| 亚洲熟女女同志女同| 91精品国产91久久自产久强 | 久久精品美女免费视频| 黑人3p华裔熟女普通话| 日本男女操逼视频免费看| 中文字幕在线欧美精品| 国产精品成人xxxx| 1区2区3区不卡视频| 日韩成人免费电影二区| 精品欧美一区二区vr在线观看 | 91麻豆精品久久久久| 91国偷自产一区二区三区精品| 九一传媒制片厂视频在线免费观看| 亚洲日产av一区二区在线| 男人天堂色男人av| 视频一区二区在线免费播放 | 日日爽天天干夜夜操| 天干天天天色天天日天天射| 综合激情网激情五月五月婷婷| 免费在线看的黄网站| tube69日本少妇| 国产大鸡巴大鸡巴操小骚逼小骚逼| 2020韩国午夜女主播在线| japanese五十路熟女熟妇| 日本韩国免费福利精品| sw137 中文字幕 在线| 国产使劲操在线播放| 少妇露脸深喉口爆吞精| 日本女大学生的黄色小视频| 黑人变态深video特大巨大| 中文字幕亚洲中文字幕| 国产精品手机在线看片| AV天堂一区二区免费试看| 天天日天天操天天摸天天舔| 日本韩国免费一区二区三区视频| 97精品综合久久在线| 黄片色呦呦视频免费看| 亚洲国产成人在线一区| 超黄超污网站在线观看| 亚洲成人av一区在线| 久久久久久9999久久久久| 成人性爱在线看四区| 78色精品一区二区三区| 人妻素人精油按摩中出| 特级欧美插插插插插bbbbb| 77久久久久国产精产品| 国产亚洲四十路五十路| 亚洲色偷偷综合亚洲AV伊人 | 精品久久久久久高潮| 一区二区视频视频视频| 国产janese在线播放| 欧美地区一二三专区| 黄色大片免费观看网站| 懂色av之国产精品| 人人妻人人澡欧美91精品| 国产黄色大片在线免费播放| 91麻豆精品传媒国产黄色片| av中文字幕福利网| 国产一区二区火爆视频| 亚洲va天堂va国产va久| 女同性ⅹxx女同h偷拍| 最新欧美一二三视频| 黄色录像鸡巴插进去| 亚洲一区二区三区久久午夜| 亚洲Av无码国产综合色区| 欧美精品一二三视频| 亚洲推理片免费看网站| 国产亚州色婷婷久久99精品| 亚洲午夜电影在线观看| 欧美香蕉人妻精品一区二区| av线天堂在线观看| 久久久久久性虐视频| 女生自摸在线观看一区二区三区| 免费岛国喷水视频在线观看 | 粉嫩欧美美人妻小视频| 少妇被强干到高潮视频在线观看| 国产精品视频欧美一区二区| 999九九久久久精品| 黄色片年轻人在线观看| 国产91嫩草久久成人在线视频| 欧美另类z0z变态| 成年美女黄网站18禁久久| 日本女人一级免费片| 亚洲综合另类精品小说| 99国内精品永久免费视频| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 中文字幕在线免费第一页| 成人伊人精品色xxxx视频| 女生被男生插的视频网站| 欧美激情精品在线观看| 国产揄拍高清国内精品对白 | 经典亚洲伊人第一页| 91综合久久亚洲综合| 成人午夜电影在线观看 久久| av资源中文字幕在线观看| 亚洲人一区二区中文字幕| 加勒比视频在线免费观看| 韩国黄色一级二级三级| 亚洲成人熟妇一区二区三区| 日辽宁老肥女在线观看视频| 午夜91一区二区三区| 久久久久久久亚洲午夜综合福利| 国产又粗又硬又猛的毛片视频| 天天日天天敢天天干| 成人高清在线观看视频| 亚洲少妇高潮免费观看| free性日本少妇| 在线观看免费视频色97| 啪啪啪操人视频在线播放| 黄色片黄色片wyaa| 在线不卡成人黄色精品| 国产成人一区二区三区电影网站| 2022精品久久久久久中文字幕| 曰本无码人妻丰满熟妇啪啪| 熟女人妻一区二区精品视频| 国内自拍第一页在线观看| wwwxxx一级黄色片| 国产97在线视频观看| 在线国产精品一区二区三区| 日韩少妇人妻精品无码专区| 欧美一区二区三区高清不卡tv| 国产麻豆乱子伦午夜视频观看| ka0ri在线视频| 少妇与子乱在线观看| 亚洲精品ww久久久久久| 午夜频道成人在线91| 九色精品视频在线播放| 蜜桃久久久久久久人妻| 亚洲推理片免费看网站| 在线不卡日韩视频播放| 日噜噜噜夜夜噜噜噜天天噜噜噜| 午夜免费观看精品视频| 日本免费一级黄色录像| 天堂女人av一区二区| 天天日天天敢天天干| 国产精品成久久久久三级蜜臀av| 男生用鸡操女生视频动漫 | 国产剧情演绎系列丝袜高跟| aiss午夜免费视频| 亚洲免费视频欧洲免费视频| 清纯美女在线观看国产| 亚国产成人精品久久久| 狠狠地躁夜夜躁日日躁| 黑人3p华裔熟女普通话| 国产精品国产三级麻豆| 日韩欧美国产一区ab| 亚洲国产欧美国产综合在线| 一本久久精品一区二区| 免费观看国产综合视频| lutube在线成人免费看| 精品美女久久久久久| 色呦呦视频在线观看视频| 亚洲伊人久久精品影院一美女洗澡| 亚洲av无硬久久精品蜜桃| 97国产在线av精品| 亚洲av第国产精品| 大屁股肉感人妻中文字幕在线| av在线免费中文字幕| 沙月文乃人妻侵犯中文字幕在线| 动漫av网站18禁| 黄色三级网站免费下载| 精品一区二区三区三区88 | 日韩美女搞黄视频免费| 成人网18免费视频版国产| 播放日本一区二区三区电影| 国产成人精品亚洲男人的天堂| 成年人的在线免费视频| 久久精品久久精品亚洲人| 91亚洲手机在线视频播放| 午夜精彩视频免费一区| 五十路av熟女松本翔子| 女警官打开双腿沦为性奴| 韩国AV无码不卡在线播放| 成人午夜电影在线观看 久久| 99一区二区在线观看| 亚洲在线免费h观看网站| 做爰视频毛片下载蜜桃视频1| 在线观看欧美黄片一区二区三区 | 亚洲欧美清纯唯美另类| 青青伊人一精品视频| 大鸡巴操b视频在线| 国产精品自拍在线视频| 插小穴高清无码中文字幕| 同居了嫂子在线播高清中文| 爱有来生高清在线中文字幕| 国产女人叫床高潮大片视频| av在线免费观看亚洲天堂| 性欧美激情久久久久久久| 欧美xxx成人在线| 亚洲天堂有码中文字幕视频| 爱有来生高清在线中文字幕| 日韩欧美国产一区ab| 大陆av手机在线观看| 亚洲黄色av网站免费播放| 成年午夜免费无码区| 亚洲美女美妇久久字幕组| 大香蕉伊人国产在线| 淫秽激情视频免费观看| 首之国产AV医生和护士小芳| 日韩二区视频一线天婷婷五| 日本高清撒尿pissing| 亚洲中文字幕综合小综合| 亚洲精品 欧美日韩| 可以免费看的www视频你懂的| 四川乱子伦视频国产vip| 日本韩国亚洲综合日韩欧美国产 | 日本少妇在线视频大香蕉在线观看| 亚洲中文精品字幕在线观看| 日本一二三中文字幕| 欧美成人精品欧美一级黄色| 特黄老太婆aa毛毛片| 亚洲国产免费av一区二区三区 | 久久久精品999精品日本| 国产精品人妻66p| 国产精品大陆在线2019不卡| 中文字幕免费在线免费| 久精品人妻一区二区三区| 国产高清女主播在线| 91精品国产综合久久久蜜 | 青青草在观免费国产精品| 日本裸体熟妇区二区欧美| 欧美精产国品一二三区| 中文字幕奴隷色的舞台50| 国产福利小视频大全| 成年人啪啪视频在线观看| 久久精品亚洲成在人线a| 岛国青草视频在线观看| 日本av在线一区二区三区| 欧美久久一区二区伊人| 亚洲成人国产av在线| 精品国产成人亚洲午夜| 黑人乱偷人妻中文字幕| 福利午夜视频在线合集| 中文亚洲欧美日韩无线码| 亚洲卡1卡2卡三卡四老狼| 91麻豆精品秘密入口在线观看| 亚洲一级特黄特黄黄色录像片| 国产又粗又黄又硬又爽| 制丝袜业一区二区三区| 夜女神免费福利视频| 亚洲 图片 欧美 图片| 91麻豆精品久久久久| 黑人3p华裔熟女普通话| 色97视频在线播放| 五色婷婷综合狠狠爱| av亚洲中文天堂字幕网| 天美传媒mv视频在线观看| 懂色av之国产精品| 人妻少妇中文有码精品| 免费人成黄页网站在线观看国产 | 精品成人午夜免费看| 麻豆精品成人免费视频| av欧美网站在线观看| 日韩一区二区电国产精品| 成人福利视频免费在线| 色婷婷精品大在线观看| 91传媒一区二区三区| jiuse91九色视频| 亚洲成人国产av在线| 亚洲av天堂在线播放| 国产变态另类在线观看| 天天日天天干天天舔天天射| 在线网站你懂得老司机| 亚洲精品午夜久久久久| 不卡精品视频在线观看| 无码日韩人妻精品久久| 粗大的内捧猛烈进出爽大牛汉子| 五十路人妻熟女av一区二区| 久久久久久久久久一区二区三区 | 亚洲丝袜老师诱惑在线观看| 日韩欧美高清免费在线| 天天摸天天干天天操科普| 玩弄人妻熟妇性色av少妇| 喷水视频在线观看这里只有精品| 老熟妇凹凸淫老妇女av在线观看| 青青擦在线视频国产在线| 国产又粗又黄又硬又爽| 9色精品视频在线观看| 国产高清在线在线视频| 一级黄片大鸡巴插入美女| 人人妻人人爽人人添夜| 国产精品成久久久久三级蜜臀av | 午夜激情高清在线观看| 精品高跟鞋丝袜一区二区| 亚洲欧美一区二区三区电影| 少妇露脸深喉口爆吞精| 少妇露脸深喉口爆吞精| 五十路熟女人妻一区二区9933| 欧洲欧美日韩国产在线| 在线不卡成人黄色精品| 男女第一次视频在线观看| 午夜在线一区二区免费| 视频二区在线视频观看| 国产伦精品一区二区三区竹菊| 精品国产污污免费网站入口自| chinese国产盗摄一区二区| av在线shipin| 人妻少妇av在线观看| 一区二区三区激情在线| 2017亚洲男人天堂| 夜鲁夜鲁狠鲁天天在线| 国产一区二区神马久久| 男人的天堂av日韩亚洲| 日韩午夜福利精品试看| 国产在线观看黄色视频| 亚洲一区二区激情在线| 中文字幕日韩91人妻在线| 欲乱人妻少妇在线视频裸| 粉嫩av蜜乳av蜜臀| 中文字幕午夜免费福利视频| 日韩成人综艺在线播放| 国产一区成人在线观看视频 | 日本乱人一区二区三区| 黄色视频成年人免费观看| 传媒在线播放国产精品一区| 深田咏美亚洲一区二区| 黄色视频在线观看高清无码| 视频 一区二区在线观看| 色秀欧美视频第一页| 日韩熟女系列一区二区三区| 天天干天天操天天摸天天射| 57pao国产一区二区| 免费啪啪啪在线观看视频| 韩国亚洲欧美超一级在线播放视频| 亚洲最大免费在线观看| 五月天中文字幕内射| 中文字幕乱码av资源| 国产 在线 免费 精品| 国产一级麻豆精品免费| 人妻无码中文字幕专区| 自拍偷拍日韩欧美一区二区| 男人的天堂一区二区在线观看| 91社福利《在线观看| 91久久国产成人免费网站| 午夜av一区二区三区| 99热99这里精品6国产| jiujiure精品视频在线| 日韩欧美国产精品91| 久久久制服丝袜中文字幕| 岛国毛片视频免费在线观看| nagger可以指黑人吗| 国产三级片久久久久久久| www日韩a级s片av| 特大黑人巨大xxxx| 最近的中文字幕在线mv视频| 天天干天天日天天干天天操| 在线免费观看亚洲精品电影| 91久久综合男人天堂| 经典亚洲伊人第一页| av老司机精品在线观看| 亚洲中文精品字幕在线观看 | 久久综合老鸭窝色综合久久 | 欧美综合婷婷欧美综合| 丰满的继坶3中文在线观看| 91国内精品久久久久精品一| 自拍偷拍,中文字幕| 欧美成人综合视频一区二区| 超级av免费观看一区二区三区| 91试看福利一分钟| av森泽佳奈在线观看| 美女吃鸡巴操逼高潮视频| 亚洲欧美一区二区三区爱爱动图| 国产普通话插插视频| av在线免费中文字幕| 中文字幕综合一区二区| 91破解版永久免费| 一区二区三区精品日本| 好吊操视频这里只有精品| 婷婷六月天中文字幕| 99久久成人日韩欧美精品| 一二三中文乱码亚洲乱码one| 久久久久久97三级| 欧美性感尤物人妻在线免费看| 精品久久久久久久久久久久人妻| 精品国产亚洲av一淫| 欧美 亚洲 另类综合| 快插进小逼里大鸡吧视频| 黄色大片免费观看网站| 很黄很污很色的午夜网站在线观看 | 欧美区一区二区三视频| 日本性感美女视频网站| 韩国一级特黄大片做受| 午夜精品九一唐人麻豆嫩草成人| 在线免费91激情四射| 日本xx片在线观看| 成人亚洲国产综合精品| 又粗又长 明星操逼小视频| 在线视频精品你懂的| 亚洲精品国产在线电影| 在线观看国产网站资源| 内射久久久久综合网| 91中文字幕最新合集| 可以免费看的www视频你懂的| 亚洲视频乱码在线观看| 在线不卡成人黄色精品| 换爱交换乱高清大片| 日本人妻少妇18—xx| 色偷偷伊人大杳蕉综合网| 人妻丰满熟妇综合网| 成人精品在线观看视频| 538精品在线观看视频| 91精品激情五月婷婷在线| 欧美日本在线视频一区| 狠狠躁狠狠爱网站视频 | 伊人综合免费在线视频| 中文字幕一区二区三区蜜月| 久久久极品久久蜜桃| 亚洲 国产 成人 在线| 动漫美女的小穴视频| 99精品一区二区三区的区| 一区二区三区日韩久久| okirakuhuhu在线观看| 男女啪啪啪啪啪的网站| 亚洲精品午夜aaa久久| 在线观看av2025| 东京干手机福利视频| 熟女国产一区亚洲中文字幕| 日曰摸日日碰夜夜爽歪歪| 在线免费91激情四射| 免费岛国喷水视频在线观看| 国产成人小视频在线观看无遮挡| 做爰视频毛片下载蜜桃视频1| 九九视频在线精品播放| 51国产偷自视频在线播放| 亚洲图片偷拍自拍区| 国产真实乱子伦a视频| 欧美一级片免费在线成人观看| 香港一级特黄大片在线播放 | 久久久久久cao我的性感人妻| 东京干手机福利视频| 可以免费看的www视频你懂的| 北条麻妃高跟丝袜啪啪| 91精品国产91久久自产久强| 亚洲美女自偷自拍11页| 国产一级麻豆精品免费| 日韩午夜福利精品试看| 日韩欧美国产一区ab| 成人影片高清在线观看| 老鸭窝在线观看一区| 天天日天天日天天射天天干| 自拍偷区二区三区麻豆| 超级福利视频在线观看| 深田咏美亚洲一区二区| 中文字幕在线欧美精品| 国产在线91观看免费观看| 人妻少妇亚洲精品中文字幕| 亚洲av琪琪男人的天堂| 国产高清女主播在线| 亚洲成人激情视频免费观看了| 啪啪啪啪啪啪啪啪av| 蜜臀av久久久久蜜臀av麻豆| 国产成人精品午夜福利训2021| 大陆精品一区二区三区久久| 国产av国片精品一区二区| 中文字幕1卡1区2区3区| 免费观看丰满少妇做受| 在线观看的a站 最新| 91大屁股国产一区二区| 开心 色 六月 婷婷| 搡老妇人老女人老熟女| 天天操天天干天天日狠狠插| 国产性生活中老年人视频网站| 久久久精品国产亚洲AV一| 瑟瑟视频在线观看免费视频| 午夜大尺度无码福利视频| 97黄网站在线观看| 日韩欧美高清免费在线| 人人爱人人妻人人澡39| 欧美黑人性暴力猛交喷水| 亚洲欧美日韩视频免费观看| 亚洲国产免费av一区二区三区 | 93精品视频在线观看| 午夜精品一区二区三区4| 欧美一区二区三区久久久aaa| 天天操天天操天天碰| 亚洲激情偷拍一区二区|