国产无遮挡裸体免费直播视频,久久精品国产蜜臀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人人爽3p| 国产内射中出在线观看| 亚洲av香蕉一区区二区三区犇| 国产一区二区在线欧美| 亚洲国产40页第21页| 丝袜美腿视频诱惑亚洲无| 亚欧在线视频你懂的| 国产精选一区在线播放| 青娱乐最新视频在线| 91九色porny蝌蚪国产成人| 国产精品大陆在线2019不卡| 亚洲欧洲一区二区在线观看| 51国产成人精品视频| 国产97视频在线精品| 蜜臀av久久久久蜜臀av麻豆| 欧美日韩在线精品一区二区三| 精品人人人妻人人玩日产欧| 色婷婷六月亚洲综合香蕉| 亚洲成人三级在线播放| 欧美亚洲偷拍自拍色图| av大全在线播放免费| 一级黄片大鸡巴插入美女| 大鸡巴后入爆操大屁股美女| 久久精品国产亚洲精品166m| 天天日天天操天天摸天天舔| 秋霞午夜av福利经典影视| 亚洲欧美国产麻豆综合| 午夜在线精品偷拍一区二| 欧美日韩亚洲国产无线码| 成人av电影免费版| 亚洲午夜电影在线观看| 鸡巴操逼一级黄色气| 综合激情网激情五月天| 亚洲成人国产综合一区| 3337p日本欧洲大胆色噜噜| av亚洲中文天堂字幕网| 老司机在线精品福利视频| 亚洲欧美综合另类13p| 亚洲国产欧美国产综合在线| 日韩剧情片电影在线收看| 婷婷午夜国产精品久久久| 亚洲欧美福利在线观看| 亚洲高清国产拍青青草原| 在线国产日韩欧美视频| av中文字幕在线观看第三页| 国产在线拍揄自揄视频网站| 香港三日本三韩国三欧美三级| 日本一道二三区视频久久| 亚洲国产成人在线一区| 一级黄片久久久久久久久| a v欧美一区=区三区| av在线观看网址av| 亚洲中文字幕人妻一区| 亚洲天堂有码中文字幕视频| 成人动漫大肉棒插进去视频| 亚洲成高清a人片在线观看| 国产在线观看黄色视频| 熟女俱乐部一二三区| 国产精品久久久黄网站| 美女张开腿让男生操在线看| 四虎永久在线精品免费区二区| 91国产资源在线视频| 狠狠鲁狠狠操天天晚上干干| 亚洲推理片免费看网站| 中文字幕在线欧美精品| 婷婷色国产黑丝少妇勾搭AV| 日本黄在免费看视频| 伊人情人综合成人久久网小说 | 日本人妻少妇18—xx| 久久久久久9999久久久久| 黑人借宿ntr人妻的沦陷2| 日韩av大胆在线观看| 亚洲精品久久综合久| 亚洲一区二区人妻av| 亚洲国产成人无码麻豆艾秋| 馒头大胆亚洲一区二区| 成人av电影免费版| 国产av国片精品一区二区| 国产一区二区视频观看| 天码人妻一区二区三区在线看| 东游记中文字幕版哪里可以看到| 亚洲中文字幕校园春色| 欧美交性又色又爽又黄麻豆| okirakuhuhu在线观看| 粉嫩av懂色av蜜臀av| 日本脱亚入欧是指什么| 日本www中文字幕| 在线免费观看靠比视频的网站| 国产福利小视频免费观看| 亚洲欧美福利在线观看| av在线播放国产不卡| 欧美精品一二三视频| 婷婷激情四射在线观看视频| 久久久精品国产亚洲AV一| 久久久制服丝袜中文字幕| 大鸡巴插入美女黑黑的阴毛| 美女张开腿让男生操在线看| 91大屁股国产一区二区| 91chinese在线视频| 欧美精品激情在线最新观看视频| 欧美成人黄片一区二区三区| 成人亚洲国产综合精品| 最近中文2019年在线看| 大鸡巴操b视频在线| 亚洲男人的天堂a在线| sspd152中文字幕在线| 手机看片福利盒子日韩在线播放| 在线免费观看欧美小视频| 黄色资源视频网站日韩| 蜜桃视频17c在线一区二区| 国产亚洲欧美另类在线观看| 国产精品黄片免费在线观看| 久久亚洲天堂中文对白| 好太好爽好想要免费| 动漫精品视频在线观看| 国产一区二区神马久久| 40道精品招牌菜特色| 日本黄色三级高清视频| 97国产在线观看高清| 亚洲精品国产久久久久久| 91chinese在线视频| 蜜桃久久久久久久人妻| 天天操夜夜骑日日摸| 精品国产亚洲av一淫| 性生活第二下硬不起来| 国产综合精品久久久久蜜臀| 国产一级精品综合av| 国产片免费观看在线观看| 在线免费观看av日韩| 国产精品伦理片一区二区| 成人资源在线观看免费官网| 天天日天天操天天摸天天舔| 一区二区三区综合视频| av欧美网站在线观看| 国产精品日韩欧美一区二区| 国产一区成人在线观看视频 | www骚国产精品视频| 偷拍自拍亚洲视频在线观看| 午夜91一区二区三区| 黄色三级网站免费下载| 日韩国产乱码中文字幕| 人妻自拍视频中国大陆| 在线观看视频污一区| 日韩剧情片电影在线收看| 日本阿v视频在线免费观看| 神马午夜在线观看视频| av手机免费在线观看高潮| 精品91高清在线观看| 99国内精品永久免费视频| 91天堂天天日天天操| 漂亮 人妻被中出中文| 精品一区二区三区三区色爱| 婷婷久久久综合中文字幕| 激情综合治理六月婷婷| 熟女少妇激情五十路| 伊人网中文字幕在线视频| 制服丝袜在线人妻中文字幕| 中文字幕在线观看极品视频| 老司机免费视频网站在线看| 亚洲成人激情av在线| 91桃色成人网络在线观看| 五月激情婷婷久久综合网| 亚洲成人激情av在线| 五十路熟女人妻一区二区9933| 一个人免费在线观看ww视频| 亚洲一级av无码一级久久精品| 啊用力插好舒服视频| 熟女在线视频一区二区三区| 久草福利电影在线观看| av在线观看网址av| 亚洲精品国品乱码久久久久 | 黄页网视频在线免费观看| 成年午夜免费无码区| 乱亲女秽乱长久久久| 亚洲激情,偷拍视频| 偷青青国产精品青青在线观看| 99热这里只有精品中文| 精品黑人巨大在线一区| 日韩午夜福利精品试看| 国产又大又黄免费观看| 欧美日本aⅴ免费视频| 亚洲成人熟妇一区二区三区| 国产综合精品久久久久蜜臀| 无套猛戳丰满少妇人妻| 天天干天天插天天谢| 成人午夜电影在线观看 久久| 午夜激情精品福利视频| 和邻居少妇愉情中文字幕| 精品av久久久久久久| 综合国产成人在线观看| 欧美女同性恋免费a| 丰满的继坶3中文在线观看| 东京干手机福利视频| 五十路在线观看完整版| 国产内射中出在线观看| 日本人妻少妇18—xx| AV无码一区二区三区不卡| 亚洲Av无码国产综合色区| 亚洲国产在线精品国偷产拍 | 日本美女性生活一级片| 91国内视频在线观看| 久久久91蜜桃精品ad| 久青青草视频手机在线免费观看 | 中文字幕av一区在线观看| 欧美一区二区三区激情啪啪啪 | 99国内精品永久免费视频| 国产真实乱子伦a视频| 精品一区二区三区欧美| 国产在线拍揄自揄视频网站| 天天干天天啪天天舔| 香港一级特黄大片在线播放| 成人免费做爰高潮视频| 人人人妻人人澡人人| 亚洲av日韩精品久久久久久hd| 国产三级片久久久久久久| 最后99天全集在线观看| 精品一区二区三区午夜| 欧美男同性恋69视频| 久久这里只有精品热视频 | 夜色17s精品人妻熟女| www日韩a级s片av| 欧美日韩激情啪啪啪| 欧美成人猛片aaaaaaa| 韩国AV无码不卡在线播放| 动漫美女的小穴视频| 午夜频道成人在线91| 亚洲av无女神免非久久| av大全在线播放免费| 久久尻中国美女视频| 欧美黑人巨大性xxxxx猛交| 99re6热在线精品| 丰满的继坶3中文在线观看| 亚洲av色图18p| 欧美美女人体视频一区| 男人的天堂av日韩亚洲| 五十路息与子猛烈交尾视频| 超级碰碰在线视频免费观看| 亚洲av色图18p| 欧美日本国产自视大全| 国产亚洲天堂天天一区| 中国熟女一区二区性xx| 人妻无码中文字幕专区| 大胆亚洲av日韩av| 人妻3p真实偷拍一二区| 欧美日韩在线精品一区二区三| 只有精品亚洲视频在线观看| 五月天中文字幕内射| h国产小视频福利在线观看| gav成人免费播放| 免费福利av在线一区二区三区| 亚洲 清纯 国产com| 欧美精产国品一二三产品区别大吗| 日日夜夜大香蕉伊人| 久久精品国产999| 1024久久国产精品| 40道精品招牌菜特色| 国产精品自拍偷拍a| 夜夜操,天天操,狠狠操| 在线观看黄色成年人网站| 粉嫩欧美美人妻小视频| av天堂资源最新版在线看| 亚洲一区制服丝袜美腿| 无码日韩人妻精品久久| av破解版在线观看| 91麻豆精品91久久久久同性| 欧美va亚洲va天堂va| 日本少妇高清视频xxxxx| 欧美特级特黄a大片免费| 久久精品亚洲国产av香蕉| 一二三中文乱码亚洲乱码one| 精品人人人妻人人玩日产欧| 成人国产激情自拍三区| 日日夜夜狠狠干视频| japanese日本熟妇另类| 适合午夜一个人看的视频| 99婷婷在线观看视频| 肏插流水妹子在线乐播下载| 日本啪啪啪啪啪啪啪| 国产精品视频欧美一区二区| 国产极品精品免费视频| 欧美特色aaa大片| 国产福利小视频二区| 日韩精品中文字幕福利| 操日韩美女视频在线免费看| 亚洲国产精品黑丝美女| 97欧洲一区二区精品免费| 福利在线视频网址导航| 亚洲免费av在线视频| 热99re69精品8在线播放| 免费无码人妻日韩精品一区二区| 中文字幕 人妻精品| 久久这里有免费精品| caoporm超碰国产| av手机在线免费观看日韩av| 宅男噜噜噜666国产| 亚洲国产在线精品国偷产拍| 婷婷六月天中文字幕| 日本a级视频老女人| 黄色大片免费观看网站| 区一区二区三国产中文字幕| 日本av高清免费网站| 日本一区二区三区免费小视频| 成人av免费不卡在线观看| 亚洲一区二区三区偷拍女厕91| 国产三级片久久久久久久| 99久久99久国产黄毛片| 天天草天天色天天干| 精品视频国产在线观看| 精品国产高潮中文字幕| 国产欧美精品一区二区高清| 国产性色生活片毛片春晓精品 | 日本美女成人在线视频| 熟女91pooyn熟女| 亚洲熟妇久久无码精品| 老司机免费福利视频网| 午夜成午夜成年片在线观看| 亚洲图片欧美校园春色| 日韩av免费观看一区| 国产精品久久9999| 巨乳人妻日下部加奈被邻居中出 | 国产真实乱子伦a视频 | 亚洲人成精品久久久久久久| 女人精品内射国产99| 国产三级精品三级在线不卡| 国产普通话插插视频| 国产成人综合一区2区| 免费在线黄色观看网站| 亚洲天堂成人在线观看视频网站 | 国产熟妇人妻ⅹxxxx麻豆| 国产精品入口麻豆啊啊啊| 51国产成人精品视频| 国产内射中出在线观看| 黄片大全在线观看观看| 久久www免费人成一看片| 2022中文字幕在线| 老鸭窝在线观看一区| 日本福利午夜电影在线观看| yy6080国产在线视频| 97人妻人人澡爽人人精品| 青青青青青青青在线播放视频| 最近中文字幕国产在线| 在线免费观看亚洲精品电影| 啊啊好大好爽啊啊操我啊啊视频| 99热99re在线播放| 欧美色婷婷综合在线| 福利视频一区二区三区筱慧| 国产亚洲视频在线观看| 97精品视频在线观看| 国产精品久久久久国产三级试频 | 国产日本欧美亚洲精品视| 男生舔女生逼逼视频| 清纯美女在线观看国产| eeuss鲁片一区二区三区| 午夜精品久久久久久99热| 中文字幕 亚洲av| 亚洲熟女综合色一区二区三区四区| 国产污污污污网站在线| 自拍偷拍 国产资源| 日本成人不卡一区二区| 东京热男人的av天堂| 欧美韩国日本国产亚洲| 88成人免费av网站| 欧美专区第八页一区在线播放 | 91桃色成人网络在线观看| 白白操白白色在线免费视频 | 日韩美女精品视频在线观看网站| 亚洲国产成人av在线一区| 国产黑丝高跟鞋视频在线播放 | 天天干天天操天天玩天天射| 免费国产性生活视频| 天堂av在线最新版在线| 不卡精品视频在线观看| 99精品免费观看视频| 人人爽亚洲av人人爽av| 色噜噜噜噜18禁止观看| 久久国产精品精品美女| 57pao国产一区二区| 91国产在线视频免费观看| 五十路熟女人妻一区二| 78色精品一区二区三区| 插逼视频双插洞国产操逼插洞| 97a片免费在线观看| 色综合色综合色综合色| 少妇人妻二三区视频| 久久香蕉国产免费天天| 男生舔女生逼逼视频| 年轻的人妻被夫上司侵犯| 偷青青国产精品青青在线观看| 国产一级精品综合av| 天天射夜夜操综合网| 亚洲人成精品久久久久久久| 涩涩的视频在线观看视频| 在线国产精品一区二区三区| 日日操综合成人av| 在线观看av观看av| 亚洲av天堂在线播放| 男人在床上插女人视频| 和邻居少妇愉情中文字幕| 青青青青操在线观看免费| 午夜影院在线观看视频羞羞羞| 阿v天堂2014 一区亚洲| 看一级特黄a大片日本片黑人| 中文字幕日韩91人妻在线| 成年人中文字幕在线观看| 五十路av熟女松本翔子| 中文字幕网站你懂的| 青草亚洲视频在线观看| 岛国一区二区三区视频在线| 国产精品污污污久久| 国产自拍在线观看成人| 国产1区,2区,3区| 欧美色婷婷综合在线| 国产伊人免费在线播放| 麻豆性色视频在线观看| 99re国产在线精品| 91片黄在线观看喷潮| 久久精品视频一区二区三区四区| 老司机在线精品福利视频| 丁香花免费在线观看中文字幕| 免费69视频在线看| 黄网十四区丁香社区激情五月天| 国产变态另类在线观看| av中文字幕在线导航| 在线观看免费视频网| 一区二区三区久久久91| 天天做天天干天天操天天射| 中文字幕高清资源站| 中文字幕一区二区自拍| 91高清成人在线视频| 黄工厂精品视频在线观看| 后入美女人妻高清在线| 亚洲日本一区二区三区| 91精品国产高清自在线看香蕉网| av网站色偷偷婷婷网男人的天堂| 肏插流水妹子在线乐播下载| 欧美日本aⅴ免费视频| 蜜桃色婷婷久久久福利在线| 一二三中文乱码亚洲乱码one| 天天色天天操天天舔| 欧美精产国品一二三产品价格| 日本高清成人一区二区三区| 久久久久久国产精品| 亚洲午夜电影在线观看| 宅男噜噜噜666免费观看| 国产视频在线视频播放| 喷水视频在线观看这里只有精品| 日本性感美女视频网站| 人妻熟女中文字幕aⅴ在线| 99久久99一区二区三区| 国产一区成人在线观看视频| 欧美亚洲免费视频观看| 哥哥姐姐综合激情小说 | 精品国产乱码一区二区三区乱| free性日本少妇| 97国产精品97久久| 国产视频在线视频播放| 精品亚洲在线免费观看| 亚洲av香蕉一区区二区三区犇| 初美沙希中文字幕在线| 不卡精品视频在线观看| 亚洲欧美福利在线观看| 蜜桃色婷婷久久久福利在线| 涩爱综合久久五月蜜臀| www久久久久久久久久久| 午夜激情精品福利视频| 一区二区久久成人网| 国产janese在线播放| 麻豆精品成人免费视频| 欧洲国产成人精品91铁牛tv| 成年人黄色片免费网站| 亚洲av无硬久久精品蜜桃| 91香蕉成人app下载| 66久久久久久久久久久| 天码人妻一区二区三区在线看| 唐人色亚洲av嫩草| 亚洲Av无码国产综合色区| 绝顶痉挛大潮喷高潮无码 | 欧美中国日韩久久精品| 国产极品美女久久久久久| 粗大的内捧猛烈进出爽大牛汉子| 亚洲人成精品久久久久久久| 姐姐的朋友2在线观看中文字幕| 欧美日韩一级黄片免费观看| 日韩av免费观看一区| 国产欧美精品不卡在线| aiss午夜免费视频| 美女 午夜 在线视频| 中文字幕在线欧美精品| 熟女人妻三十路四十路人妻斩| 中文字幕在线乱码一区二区| 精品区一区二区三区四区人妻 | 美女小视频网站在线| 美女吃鸡巴操逼高潮视频| 日本av在线一区二区三区| v888av在线观看视频| 亚洲少妇人妻无码精品| 超污视频在线观看污污污| 亚洲人妻30pwc| 亚洲成人三级在线播放| 亚洲av日韩精品久久久久久hd| 丰满的继坶3中文在线观看| 国产福利小视频大全| 亚洲欧美一区二区三区电影| 日本女大学生的黄色小视频| 521精品视频在线观看| 色呦呦视频在线观看视频| 家庭女教师中文字幕在线播放| 一区二区三区激情在线| 大骚逼91抽插出水视频| 亚洲精品国产在线电影| 日韩av大胆在线观看| 亚洲欧美成人综合视频| 99一区二区在线观看| 亚洲av日韩精品久久久久久hd| 国产欧美精品一区二区高清| 中文字幕欧美日韩射射一| 91精品国产黑色丝袜| 99久久99久国产黄毛片| 快点插进来操我逼啊视频| 国产日韩av一区二区在线| 老司机福利精品免费视频一区二区| 亚洲精品乱码久久久本| 99婷婷在线观看视频| 天堂va蜜桃一区入口| 亚洲粉嫩av一区二区三区| 久久精品久久精品亚洲人| 午夜精品一区二区三区福利视频| 日本男女操逼视频免费看| 11久久久久久久久久久| 日本性感美女三级视频| 午夜激情精品福利视频| 色婷婷综合激情五月免费观看| 美洲精品一二三产区区别| 欧美精品亚洲精品日韩在线| 亚洲午夜精品小视频| 97精品视频在线观看| 亚洲成人免费看电影| 黄色片黄色片wyaa| aaa久久久久久久久| 2021天天色天天干| 亚洲国产在线精品国偷产拍| 成人亚洲国产综合精品| 久久99久久99精品影院| 国产九色91在线观看精品| 久久热久久视频在线观看| 久久久久久久久久久免费女人| 又黄又刺激的午夜小视频| 3344免费偷拍视频| 欧美黑人性猛交xxxxⅹooo| 亚洲2021av天堂| 在线免费观看欧美小视频| 日本黄色特一级视频| 男人天堂色男人av| 九色精品视频在线播放| 红桃av成人在线观看| 国产一区二区火爆视频| 女人精品内射国产99| 午夜精品亚洲精品五月色| 丝袜美腿欧美另类 中文字幕| 黄色片黄色片wyaa| 国产久久久精品毛片| 日本成人一区二区不卡免费在线| av久久精品北条麻妃av观看| 在线 中文字幕 一区| 红桃av成人在线观看| 亚洲视频在线视频看视频在线| 2021天天色天天干| 日本性感美女三级视频| 男人操女人的逼免费视频| 国产精品国产三级麻豆| 91高清成人在线视频| 亚洲 人妻 激情 中文| 扒开让我视频在线观看| 成人av久久精品一区二区| 国产成人午夜精品福利| 欧美精品激情在线最新观看视频| 扒开让我视频在线观看| 国产精品国产三级麻豆| 经典av尤物一区二区| 亚洲成人三级在线播放 | 亚洲变态另类色图天堂网| 五月天久久激情视频| 亚洲成人国产综合一区| 中文字幕成人日韩欧美| 青青青青青青青青青青草青青 | 青青尤物在线观看视频网站| 国产福利在线视频一区| 91久久人澡人人添人人爽乱| 欧美激情精品在线观看| 精品成人午夜免费看| sspd152中文字幕在线| 亚洲综合一区成人在线| av在线shipin| 亚洲熟妇无码一区二区三区| 国产三级精品三级在线不卡| 91大神福利视频网| 亚洲特黄aaaa片| 天天插天天色天天日| 九色视频在线观看免费| 久久久噜噜噜久久熟女av| 老司机福利精品视频在线| 欧美成人精品欧美一级黄色| 香港一级特黄大片在线播放| 午夜精品亚洲精品五月色| 久久久久五月天丁香社区| 国产成人综合一区2区| 大香蕉玖玖一区2区| 国产97在线视频观看| 欧美亚洲自偷自拍 在线| 黄色成年网站午夜在线观看| 日本成人一区二区不卡免费在线| 偷拍美女一区二区三区| 亚洲人妻视频在线网| 青青青国产免费视频| 亚洲中文字幕人妻一区| 在线可以看的视频你懂的| 日韩av有码一区二区三区4| 欧美爆乳肉感大码在线观看| 女生自摸在线观看一区二区三区| 亚洲成人免费看电影| 日韩精品啪啪视频一道免费| 色综合久久久久久久久中文| brazzers欧熟精品系列| 懂色av之国产精品| 91大屁股国产一区二区| 成人乱码一区二区三区av| 在线不卡成人黄色精品| 性欧美日本大妈母与子| 综合页自拍视频在线播放| 国产清纯美女al在线| 国产成人综合一区2区| 偷拍自拍国产在线视频| 日韩美女搞黄视频免费| 成人av久久精品一区二区| 一区二区三区国产精选在线播放| 亚洲精品在线资源站| 国产在线一区二区三区麻酥酥| 精品成人午夜免费看| 天天日天天日天天擦| 精品91自产拍在线观看一区| 国产精彩福利精品视频| 亚洲国产成人在线一区| 青青色国产视频在线| 不卡一区一区三区在线| 不卡精品视频在线观看| 日本最新一二三区不卡在线| 亚洲成人av在线一区二区| 五十路老熟女码av| 国产V亚洲V天堂无码欠欠| 免费男阳茎伸入女阳道视频| 在线观看成人国产电影| 亚洲国产欧美一区二区三区久久| 中文乱理伦片在线观看| 国产高清97在线观看视频| 日本少妇在线视频大香蕉在线观看 | 午夜毛片不卡免费观看视频| 大香蕉日本伊人中文在线| 超黄超污网站在线观看| 9国产精品久久久久老师| 人人爱人人妻人人澡39| 超碰中文字幕免费观看| 九九视频在线精品播放| 黑人变态深video特大巨大| 一二三中文乱码亚洲乱码one| 女同性ⅹxx女同h偷拍| 精品日产卡一卡二卡国色天香 | 97色视频在线观看| 日本av高清免费网站| 国产精选一区在线播放| 91麻豆精品91久久久久同性| 国产精品手机在线看片| 一区二区三区在线视频福利| 日本午夜福利免费视频| 欧美一区二区三区乱码在线播放| 天天日天天摸天天爱| 9国产精品久久久久老师| 久久丁香花五月天色婷婷| 欧美一级色视频美日韩| 国产精品黄页网站视频| 国产精品伦理片一区二区| 国产美女一区在线观看| 喷水视频在线观看这里只有精品| 中文字幕 码 在线视频| 免费在线观看视频啪啪| 精品一区二区三区在线观看| 黄色录像鸡巴插进去| 亚洲另类在线免费观看| 亚洲国产精品美女在线观看| 爱爱免费在线观看视频| 人妻少妇精品久久久久久| 国产熟妇乱妇熟色T区| 欧美亚洲自偷自拍 在线| 天天操夜夜骑日日摸| 亚洲精品在线资源站| 清纯美女在线观看国产| 40道精品招牌菜特色| 色天天天天射天天舔| 无码日韩人妻精品久久| 成人亚洲精品国产精品| 亚洲精品一线二线在线观看| 中国老熟女偷拍第一页| 精品久久久久久久久久久99| 91自产国产精品视频| 午夜国产免费福利av| 黄色录像鸡巴插进去| 一区二区三区久久久91| 超碰中文字幕免费观看| 国产高清女主播在线| 91天堂天天日天天操| 黄色录像鸡巴插进去| 中文字幕+中文字幕| 91p0rny九色露脸熟女| 五月婷婷在线观看视频免费| 日韩欧美亚洲熟女人妻| 中国熟女一区二区性xx| 红桃av成人在线观看| 欧美男人大鸡吧插女人视频| 亚洲特黄aaaa片| 亚洲免费va在线播放| 日本后入视频在线观看| 国产精品亚洲在线观看| 国产精品人妻66p| 99的爱精品免费视频| 亚洲国产成人在线一区| av无限看熟女人妻另类av| 2022天天干天天操| 桃色视频在线观看一区二区| 亚洲国产美女一区二区三区软件 | 绝顶痉挛大潮喷高潮无码| 日韩欧美亚洲熟女人妻| 青青青aaaa免费| 中文字日产幕乱六区蜜桃| 亚洲av色香蕉一区二区三区| 3344免费偷拍视频| 91久久综合男人天堂| 午夜精品亚洲精品五月色| 亚洲 中文字幕在线 日韩| 粗大的内捧猛烈进出爽大牛汉子| 午夜激情久久不卡一区二区| 亚洲欧美成人综合在线观看| 中文字幕日韩无敌亚洲精品| 日韩精品中文字幕在线| 国产丰满熟女成人视频| 欧美特级特黄a大片免费| 99精品久久久久久久91蜜桃| 亚洲美女自偷自拍11页| 91 亚洲视频在线观看| 78色精品一区二区三区| 久久三久久三久久三久久| 欧美日本国产自视大全| av视屏免费在线播放| 人妻凌辱欧美丰满熟妇| 91在线视频在线精品3| 无套猛戳丰满少妇人妻| 色哟哟国产精品入口| 久久这里只有精品热视频| 沈阳熟妇28厘米大战黑人| 久久免费看少妇高潮完整版| 中文字幕+中文字幕| 国产麻豆乱子伦午夜视频观看| 人人人妻人人澡人人| 国产麻豆剧传媒精品国产av蜜桃| 国产一区av澳门在线观看| 中文亚洲欧美日韩无线码| 亚洲国产在线精品国偷产拍 | 欧美黄片精彩在线免费观看 | 91天堂精品一区二区| 亚洲成人精品女人久久久| 在线观看免费岛国av| 亚洲精品ww久久久久久| 久久久久久cao我的性感人妻 | 婷婷久久久久深爱网| 老司机欧美视频在线看| 丰满少妇翘臀后进式| 丝袜肉丝一区二区三区四区在线看| 成人av电影免费版| 中文字幕在线永久免费播放| 最新中文字幕乱码在线| 动色av一区二区三区| 亚洲精品ww久久久久久| 国产视频一区在线观看| 88成人免费av网站| 老司机午夜精品视频资源| 免费在线播放a级片| 亚洲自拍偷拍综合色| tube69日本少妇| 91精品资源免费观看| 国产精品手机在线看片| aⅴ五十路av熟女中出| 精品久久久久久久久久久久人妻| 精品人妻一二三区久久| 日韩欧美中文国产在线| 天天干天天日天天干天天操| 日本熟妇色熟妇在线观看| 福利午夜视频在线观看| 国产极品精品免费视频| 一区二区三区日韩久久| 制丝袜业一区二区三区| 新婚人妻聚会被中出| 天天摸天天亲天天舔天天操天天爽| 国产精品国产三级国产午| 亚洲一区自拍高清免费视频| 一区二区熟女人妻视频| 另类av十亚洲av| 亚洲 中文 自拍 无码| 91人妻精品久久久久久久网站| 2012中文字幕在线高清| 亚洲一区二区三区精品视频在线| 青青青青草手机在线视频免费看| 免费观看国产综合视频| 操的小逼流水的文章| 国产综合高清在线观看| 国产熟妇乱妇熟色T区| 日本又色又爽又黄又粗| 日本少妇的秘密免费视频| av中文字幕网址在线| 中文字幕一区二 区二三区四区| 日韩午夜福利精品试看| 亚洲一区二区三区久久午夜| 美洲精品一二三产区区别| 日韩一区二区电国产精品| 亚洲综合乱码一区二区| av中文字幕电影在线看| 日本a级视频老女人| 国产精品3p和黑人大战| 强行扒开双腿猛烈进入免费版| 38av一区二区三区| 久久三久久三久久三久久| 婷婷午夜国产精品久久久| 肏插流水妹子在线乐播下载 | 国产福利在线视频一区| 日韩熟女系列一区二区三区| 2021天天色天天干| 中文字幕视频一区二区在线观看| 久久热这里这里只有精品| 2022天天干天天操| 97精品人妻一区二区三区精品| 19一区二区三区在线播放| 青青青青青青草国产| 最新国产精品网址在线观看| 91麻豆精品秘密入口在线观看| 亚洲欧美成人综合在线观看| 日韩熟女系列一区二区三区| 特级无码毛片免费视频播放| 亚洲综合另类欧美久久| 伊人精品福利综合导航| 青青青视频手机在线观看| 大鸡吧插逼逼视频免费看| 亚洲国产欧美国产综合在线| 精品老妇女久久9g国产| 欧亚日韩一区二区三区观看视频| 乱亲女秽乱长久久久| av中文字幕国产在线观看| 国产精品免费不卡av| 中文字幕+中文字幕| 国产一区二区在线欧美| 日韩二区视频一线天婷婷五| 2019av在线视频| 大胆亚洲av日韩av| 2021国产一区二区| 自拍偷拍一区二区三区图片 | 国产高清在线在线视频| 91九色porny蝌蚪国产成人| 亚洲国产欧美一区二区三区久久| 成人精品在线观看视频| 免费69视频在线看| 亚洲色偷偷综合亚洲AV伊人| 在线观看日韩激情视频| 国产熟妇一区二区三区av| 国产中文字幕四区在线观看| 欧美日韩情色在线观看| 久草视频在线一区二区三区资源站 | 国产麻豆91在线视频| 2020国产在线不卡视频 | 欧美精品免费aaaaaa| 任你操任你干精品在线视频| 青青草成人福利电影| 91chinese在线视频| av黄色成人在线观看| 欧美日本国产自视大全| 中文字幕在线观看极品视频| 91啪国自产中文字幕在线| 青青草原色片网站在线观看| 青青青青在线视频免费观看| 亚洲精品ww久久久久久| 成人高潮aa毛片免费| 操日韩美女视频在线免费看| 98精产国品一二三产区区别| 精品久久久久久高潮| 欧美亚洲一二三区蜜臀| 毛片av在线免费看| 美女视频福利免费看| 午夜精品一区二区三区福利视频| 国产av福利网址大全| 可以在线观看的av中文字幕| 人妻少妇亚洲一区二区| 久草视频在线免播放| 免费av岛国天堂网站| 天码人妻一区二区三区在线看 | 久久精品久久精品亚洲人| 天堂中文字幕翔田av| 中文字幕亚洲久久久| 国产使劲操在线播放| 久久午夜夜伦痒痒想咳嗽P| 99热国产精品666| 亚洲护士一区二区三区| 91中文字幕最新合集| 啪啪啪18禁一区二区三区| 丰满的继坶3中文在线观看| 高潮视频在线快速观看国家快速| 色综合天天综合网国产成人| 日本黄色特一级视频| 综合一区二区三区蜜臀| 国产三级影院在线观看| 国产日韩精品一二三区久久久| 亚洲成人线上免费视频观看| 亚洲成人免费看电影| 91中文字幕最新合集| 97a片免费在线观看| 班长撕开乳罩揉我胸好爽| 中国黄片视频一区91| 日韩av免费观看一区| 免费无码人妻日韩精品一区二区| 亚洲午夜电影之麻豆| 天天插天天狠天天操| 11久久久久久久久久久| 红桃av成人在线观看| 一区二区三区美女毛片| 欧美在线一二三视频| 69精品视频一区二区在线观看 | 亚洲国产精品免费在线观看| 91精品一区二区三区站长推荐| 国际av大片在线免费观看| 免费高清自慰一区二区三区网站 | 日本av在线一区二区三区| 国产精品视频男人的天堂| 国产亚洲成人免费在线观看 | 国产精品亚洲在线观看| 亚洲免费福利一区二区三区| 热久久只有这里有精品| 亚洲蜜臀av一区二区三区九色| 人妻丝袜榨强中文字幕| 新婚人妻聚会被中出| 最新国产精品网址在线观看| av高潮迭起在线观看| 精品91自产拍在线观看一区| 欧美亚洲免费视频观看| 日本熟女50视频免费| 成人动漫大肉棒插进去视频| lutube在线成人免费看| 天堂av狠狠操蜜桃| av完全免费在线观看av| 涩爱综合久久五月蜜臀| 国产日韩精品一二三区久久久| 国产在线免费观看成人| 久久久久久97三级| 日本中文字幕一二区视频| 五月天久久激情视频| 免费观看丰满少妇做受| 久久精品在线观看一区二区| 国产污污污污网站在线| 在线观看免费av网址大全| 视频一区 视频二区 视频| 91香蕉成人app下载| 色噜噜噜噜18禁止观看| 视频一区 视频二区 视频| 中文字幕一区二区三区蜜月| 成人性爱在线看四区| 亚洲av日韩av网站| 亚洲av男人天堂久久| 一区二区三区欧美日韩高清播放| 88成人免费av网站| 日本女大学生的黄色小视频| 中国把吊插入阴蒂的视频| 在线免费观看视频一二区| 五十路人妻熟女av一区二区 | 一区二区三区 自拍偷拍| 中文字幕人妻三级在线观看| 99视频精品全部15| 日本乱人一区二区三区| 5528327男人天堂| 欧美伊人久久大香线蕉综合| 国内精品在线播放第一页| 日本一本午夜在线播放| 特大黑人巨大xxxx| 播放日本一区二区三区电影| 亚洲1区2区3区精华液| 偷拍3456eee| 亚洲人妻视频在线网| 美女视频福利免费看| 日韩近亲视频在线观看| 国产精品久久久黄网站| 自拍偷拍日韩欧美一区二区| 国产亚洲欧美45p| 人妻熟女在线一区二区| 亚洲中文精品人人免费| 久久久久久久精品成人热| 亚洲午夜在线视频福利| 午夜精品一区二区三区城中村| 韩国黄色一级二级三级| 2019av在线视频| 在线免费观看黄页视频| 亚洲一区二区激情在线| 美味人妻2在线播放| av俺也去在线播放| 福利片区一区二体验区| 激情国产小视频在线| 国产日本精品久久久久久久| 日本女大学生的黄色小视频| 欧美精品国产综合久久| av大全在线播放免费| 97香蕉碰碰人妻国产樱花| 在线观看日韩激情视频| 色婷婷精品大在线观看| 第一福利视频在线观看| 精品人妻伦一二三区久| 亚洲午夜电影之麻豆| 男人操女人的逼免费视频| 国产精品3p和黑人大战| www日韩a级s片av| 2021天天色天天干| xxx日本hd高清| 97人人妻人人澡人人爽人人精品| 91精品国产高清自在线看香蕉网| 国产真实乱子伦a视频| 亚洲特黄aaaa片| 51国产成人精品视频| 青青色国产视频在线| 人妻少妇精品久久久久久| 精品suv一区二区69| 欧美日韩一级黄片免费观看| 精品91自产拍在线观看一区| 超pen在线观看视频公开97| 大陆精品一区二区三区久久| 国产精品久久久久网| av手机在线免费观看日韩av| 色婷婷久久久久swag精品| 国产精品成人xxxx| aiss午夜免费视频| 超碰公开大香蕉97| 在线免费观看av日韩| 黄色的网站在线免费看| 都市激情校园春色狠狠| 欧美久久一区二区伊人| 国产av一区2区3区| 天天干夜夜操啊啊啊| 欧美综合婷婷欧美综合| 蜜桃色婷婷久久久福利在线| 中文字幕一区二区人妻电影冢本| av天堂资源最新版在线看| 喷水视频在线观看这里只有精品| 少妇人妻二三区视频| 中文字幕一区二 区二三区四区| 亚洲中文精品字幕在线观看| 熟女91pooyn熟女| 人人在线视频一区二区| 91www一区二区三区| 黄片三级三级三级在线观看| 亚洲伊人久久精品影院一美女洗澡| 日韩在线视频观看有码在线| 玩弄人妻熟妇性色av少妇| 亚洲青青操骚货在线视频| 亚洲在线一区二区欧美| 精品久久久久久久久久久99| 桃色视频在线观看一区二区| 人妻少妇性色欲欧美日韩| 国产福利在线视频一区| 五十路熟女人妻一区二| 欧美一区二区三区激情啪啪啪 | 97精品人妻一区二区三区精品| av黄色成人在线观看| 亚洲精品国产久久久久久| 极品丝袜一区二区三区| 日韩欧美在线观看不卡一区二区 | 快点插进来操我逼啊视频| 国产在线免费观看成人| 99精品国产aⅴ在线观看| 成人av免费不卡在线观看| 成人H精品动漫在线无码播放| 男人天堂最新地址av| 欧美精产国品一二三区| 天天躁日日躁狠狠躁av麻豆| av在线资源中文字幕| 天码人妻一区二区三区在线看| 一区二区视频在线观看视频在线| av视屏免费在线播放| 自拍偷拍亚洲欧美在线视频| 日日夜夜狠狠干视频| 一区二区三区激情在线| 9国产精品久久久久老师| 免费一级特黄特色大片在线观看| 在线视频这里只有精品自拍| 2020久久躁狠狠躁夜夜躁| 美女骚逼日出水来了| 色花堂在线av中文字幕九九| 国产又粗又硬又猛的毛片视频| 久草视频首页在线观看| 欧美一区二区三区久久久aaa| 午夜影院在线观看视频羞羞羞| 国产又粗又黄又硬又爽| 熟女俱乐部一二三区| 天天操天天干天天插| 欧美少妇性一区二区三区| 一本一本久久a久久精品综合不卡| 爱爱免费在线观看视频| 伊人精品福利综合导航| 国产福利小视频二区| 综合激情网激情五月五月婷婷| 亚洲激情,偷拍视频| 欧美亚洲一二三区蜜臀| 一区二区三区国产精选在线播放| tube69日本少妇| 国产女人露脸高潮对白视频| 制服丝袜在线人妻中文字幕| 91亚洲国产成人精品性色| 亚洲国际青青操综合网站| 亚洲欧美综合另类13p| 91p0rny九色露脸熟女| 51精品视频免费在线观看| 91‖亚洲‖国产熟女| 夜鲁夜鲁狠鲁天天在线| 亚洲一区二区三区av网站| 欧美怡红院视频在线观看| 成人乱码一区二区三区av| 天天操天天射天天操天天天| 天天日天天透天天操| 快点插进来操我逼啊视频| 亚洲av香蕉一区区二区三区犇| 经典亚洲伊人第一页| 欧美区一区二区三视频| 一区二区三区四区中文| 中文字幕一区二 区二三区四区 | 成人免费公开视频无毒| 亚洲1区2区3区精华液| 亚洲av成人免费网站| 人妻无码色噜噜狠狠狠狠色| 久草福利电影在线观看| 亚洲高清国产拍青青草原| 欧美亚洲偷拍自拍色图| 日韩美女精品视频在线观看网站| 中文字幕综合一区二区| 久久久久久97三级| 中文字幕一区二 区二三区四区 | 黑人借宿ntr人妻的沦陷2| 国产自拍在线观看成人| 免费看国产又粗又猛又爽又黄视频| 大鸡巴后入爆操大屁股美女| 国产乱子伦精品视频潮优女| 天天日天天透天天操| 中文字幕人妻av在线观看| 经典国语激情内射视频| av视网站在线观看| 91久久精品色伊人6882| 国产精品视频欧美一区二区| 大黑人性xxxxbbbb| 2021国产一区二区| 在线国产中文字幕视频| 久精品人妻一区二区三区| 天天干天天操天天扣| 一区国内二区日韩三区欧美| 精品欧美一区二区vr在线观看| 一级A一级a爰片免费免会员| 色天天天天射天天舔| 国产熟妇乱妇熟色T区| 中文字幕 码 在线视频| 日本三极片视频网站观看| 国产一区成人在线观看视频 | 激情内射在线免费观看| 亚洲福利天堂久久久久久| 天堂av中文在线最新版| 少妇人妻真实精品视频| 在线免费观看日本片| 免费高清自慰一区二区三区网站| 午夜免费体验区在线观看| 大香蕉大香蕉在线有码 av| 91色九色porny| aⅴ精产国品一二三产品| 亚洲男人的天堂a在线| japanese五十路熟女熟妇| 日韩中文字幕福利av| 亚洲区美熟妇久久久久| 亚洲综合一区成人在线| 色吉吉影音天天干天天操| 97年大学生大白天操逼| av网站色偷偷婷婷网男人的天堂| 亚洲天堂av最新网址| 狠狠地躁夜夜躁日日躁| 中文字幕之无码色多多| 日本午夜爽爽爽爽爽视频在线观看 | 在线 中文字幕 一区| 在线观看操大逼视频| 大鸡巴操娇小玲珑的女孩逼| 男生用鸡操女生视频动漫| 欧美亚洲少妇福利视频| 欧美精品中文字幕久久二区| 精品久久久久久久久久中文蒉| 宅男噜噜噜666国产| 欧美成人综合视频一区二区 | 福利国产视频在线观看| 成年女人免费播放视频| 国产成人精品一区在线观看 | 狠狠的往里顶撞h百合| 中文字幕av男人天堂| 91久久综合男人天堂| 国产剧情演绎系列丝袜高跟| 搡老妇人老女人老熟女| 在线观看亚洲人成免费网址| 亚洲 欧美 精品 激情 偷拍| 亚洲午夜精品小视频| 日韩剧情片电影在线收看| 青青青青草手机在线视频免费看| 天天日天天玩天天摸| 大胸性感美女羞爽操逼毛片| 男女啪啪啪啪啪的网站| 天天操天天射天天操天天天| 国产精品大陆在线2019不卡| 成人精品视频99第一页| 日本最新一二三区不卡在线| 国产 在线 免费 精品| 日本一区二区三区免费小视频| 1区2区3区4区视频在线观看| 欧美80老妇人性视频| 亚洲中文字幕乱码区| 热思思国产99re| 中文字幕人妻三级在线观看| 班长撕开乳罩揉我胸好爽| 国产熟妇一区二区三区av| 粉嫩av懂色av蜜臀av| 欧美80老妇人性视频| 天天干天天啪天天舔| 亚洲精品在线资源站| 一色桃子久久精品亚洲| 亚洲一级美女啪啪啪| 老司机99精品视频在线观看| 大香蕉伊人国产在线| 人妻最新视频在线免费观看| 女同性ⅹxx女同hd| 韩国一级特黄大片做受| 美女大bxxxx内射| 天天干夜夜操啊啊啊| 国产成人精品午夜福利训2021| 一区二区三区激情在线| tube69日本少妇| 黄色片黄色片wyaa| 精品一区二区亚洲欧美| 人妻熟女中文字幕aⅴ在线 | 亚洲日本一区二区三区| 国产揄拍高清国内精品对白| 精品亚洲在线免费观看| 五月天久久激情视频| 久草视频在线看免费| 99人妻视频免费在线| 五月天色婷婷在线观看视频免费| 小泽玛利亚视频在线观看| 国产女孩喷水在线观看| 日韩国产乱码中文字幕| 大香蕉福利在线观看| 日本女人一级免费片| 中文字幕人妻被公上司喝醉在线| 国产熟妇一区二区三区av| 啊啊好慢点插舔我逼啊啊啊视频 | 国产美女精品福利在线| 99re6热在线精品| 男人的天堂av日韩亚洲| 亚洲欧美久久久久久久久| 国产白袜脚足J棉袜在线观看| 制丝袜业一区二区三区| 精品成人午夜免费看| 在线播放国产黄色av| 中国视频一区二区三区| 视频 一区二区在线观看| 国产高清在线在线视频| 又粗又长 明星操逼小视频 | 黄片大全在线观看观看| 色综合久久五月色婷婷综合| av无限看熟女人妻另类av| 国产视频在线视频播放| 精品一区二区三区午夜| 一区二区三区另类在线| 欧美专区第八页一区在线播放| 日本少妇精品免费视频| 亚洲天堂第一页中文字幕| 国产精品伦理片一区二区| 中文字幕在线第一页成人| 狠狠的往里顶撞h百合| 香蕉91一区二区三区| 一区二区视频在线观看视频在线| 中文字幕在线免费第一页| 唐人色亚洲av嫩草| 无码日韩人妻精品久久| 欧美日韩国产一区二区三区三州| 天天干天天操天天爽天天摸| 国产一线二线三线的区别在哪 | 亚洲码av无色中文| 青青青视频自偷自拍38碰| av在线免费观看亚洲天堂| 宅男噜噜噜666免费观看| 91精品国产黑色丝袜| 视频在线亚洲一区二区| 精品一区二区三区三区88| 中字幕人妻熟女人妻a62v网| 男人操女人逼逼视频网站| 天天日天天干天天插舔舔| 久久久久久国产精品| av网址在线播放大全| 毛片av在线免费看| 91自产国产精品视频| 把腿张开让我插进去视频| 中文字幕AV在线免费看 | 日韩剧情片电影在线收看| 91精品国产综合久久久蜜| 日本少妇人妻xxxxx18| 亚洲国产香蕉视频在线播放| 黄色视频在线观看高清无码 | 91精品免费久久久久久| 操的小逼流水的文章| 亚洲人成精品久久久久久久| 97人妻无码AV碰碰视频| 亚洲国产美女一区二区三区软件| 青青青国产片免费观看视频| 在线观看av亚洲情色| 成人影片高清在线观看| 黄色男人的天堂视频| 国产麻豆91在线视频| 欧美一区二区中文字幕电影 | 国产麻豆91在线视频| 精品高跟鞋丝袜一区二区| 国产精品手机在线看片| 喷水视频在线观看这里只有精品| 天天干天天操天天插天天日| 精品人妻每日一部精品| 第一福利视频在线观看| 天天日天天干天天要| 美女大bxxxx内射| 天天草天天色天天干| 18禁网站一区二区三区四区 | 亚洲另类伦春色综合小| 久久久久久99国产精品| 欧美一级色视频美日韩| 大香蕉大香蕉在线看| 欧美视频不卡一区四区| 国产成人一区二区三区电影网站| 免费看美女脱光衣服的视频| 又粗又硬又猛又爽又黄的| 岛国av高清在线成人在线| 丝袜肉丝一区二区三区四区在线看| 精彩视频99免费在线| yellow在线播放av啊啊啊| 人妻少妇亚洲精品中文字幕| 福利国产视频在线观看| 天天日天天干天天插舔舔| 人妻激情图片视频小说| 日本av在线一区二区三区| 大香蕉大香蕉大香蕉大香蕉大香蕉| 国产免费高清视频视频| 毛片一级完整版免费| 亚洲一区二区三区uij| 99热99这里精品6国产| 岛国免费大片在线观看| 91小伙伴中女熟女高潮| 福利一二三在线视频观看| 国产性色生活片毛片春晓精品| 日本人妻少妇18—xx| 日韩影片一区二区三区不卡免费| 性感美女诱惑福利视频| 狠狠鲁狠狠操天天晚上干干| 亚洲乱码中文字幕在线| 蜜桃色婷婷久久久福利在线| 欧美一区二区三区久久久aaa| 黄色成人在线中文字幕| 成人性爱在线看四区| 久久久久久9999久久久久| 欧美亚洲国产成人免费在线 | 日韩近亲视频在线观看| 搡老妇人老女人老熟女| 91精品国产91青青碰| 丰满的子国产在线观看| 国产精品国产三级麻豆| 亚洲天堂第一页中文字幕| 春色激情网欧美成人| 天天色天天操天天舔| 欧美成人猛片aaaaaaa| 午夜婷婷在线观看视频| 一区二区三区欧美日韩高清播放| 成人av免费不卡在线观看| 1区2区3区4区视频在线观看| 偷偷玩弄新婚人妻h视频| 欧美专区第八页一区在线播放| 国产三级片久久久久久久 | 午夜免费观看精品视频| 亚洲 图片 欧美 图片| 毛茸茸的大外阴中国视频| 青青草原色片网站在线观看| 亚洲一级av无码一级久久精品| 亚洲av色图18p| 亚洲麻豆一区二区三区| 少妇ww搡性bbb91| 老司机在线精品福利视频| 亚洲av可乐操首页| 日本xx片在线观看| 人人妻人人爽人人澡人人精品| 少妇人妻真实精品视频| 99国产精品窥熟女精品| 国产精品国产三级国产午| 人妻激情图片视频小说| 999久久久久999| 99精品视频在线观看免费播放| 2012中文字幕在线高清| 国产不卡av在线免费| 99精品国自产在线人| 在线国产中文字幕视频| 亚洲欧美成人综合在线观看| 久久热这里这里只有精品| 精品国产乱码一区二区三区乱| 韩国女主播精品视频网站| 自拍偷拍亚洲欧美在线视频| 97精品成人一区二区三区| 亚洲精品国品乱码久久久久| 日本欧美视频在线观看三区| 爆乳骚货内射骚货内射在线| 欧美伊人久久大香线蕉综合| 亚洲一级美女啪啪啪| av老司机精品在线观看| 亚洲一区二区三区在线高清 | 55夜色66夜色国产精品站| 国产夫妻视频在线观看免费| 激情五月婷婷综合色啪| 亚洲激情偷拍一区二区| 大陆胖女人与丈夫操b国语高清| 边摸边做超爽毛片18禁色戒| 日本韩国亚洲综合日韩欧美国产| 欧美xxx成人在线| 97色视频在线观看| 日韩熟女系列一区二区三区| 亚洲自拍偷拍精品网| av线天堂在线观看| 女同互舔一区二区三区| 色哟哟在线网站入口| 日韩在线中文字幕色| 久久三久久三久久三久久| 激情小视频国产在线| 日韩精品激情在线观看| 啊慢点鸡巴太大了啊舒服视频| 强行扒开双腿猛烈进入免费版 | 人妻另类专区欧美制服| 大鸡巴操b视频在线| 天天干天天日天天谢综合156| 国产精品大陆在线2019不卡| 淫秽激情视频免费观看| 亚洲午夜电影之麻豆| 天天操天天插天天色| 国产成人精品av网站| 天天操天天爽天天干| 美女福利视频导航网站| 中国把吊插入阴蒂的视频| 久久久人妻一区二区| 蝴蝶伊人久久中文娱乐网| 精品一区二区三区三区色爱| 精品视频国产在线观看| 亚洲激情偷拍一区二区| 任你操视频免费在线观看| 国产黑丝高跟鞋视频在线播放| 99久久99久国产黄毛片| 夜夜躁狠狠躁日日躁麻豆内射 | 免费在线观看视频啪啪| 国产在线自在拍91国语自产精品| 久草视频在线一区二区三区资源站| 蜜桃视频17c在线一区二区| 欧美精品伦理三区四区| 91大屁股国产一区二区| 精品一线二线三线日本| 欧美成人一二三在线网| wwwxxx一级黄色片| 一级黄色片夫妻性生活| 成人av中文字幕一区| 2012中文字幕在线高清| 性感美女高潮视频久久久 | 日本人竟这样玩学生妹| 男人的天堂av日韩亚洲| 亚洲天堂第一页中文字幕| 国产V亚洲V天堂无码欠欠| 国产露脸对白在线观看| 天天摸天天日天天操| 韩国AV无码不卡在线播放| 一区二区三区激情在线| 好男人视频在线免费观看网站| 熟女在线视频一区二区三区| 黑人借宿ntr人妻的沦陷2| 大肉大捧一进一出好爽在线视频| 天天日夜夜干天天操| 欧美女同性恋免费a| 久碰精品少妇中文字幕av| 黄色大片男人操女人逼| 亚洲人妻视频在线网| 9久在线视频只有精品| 97少妇精品在线观看| 欧美熟妇一区二区三区仙踪林 | 骚货自慰被发现爆操| 国产精品手机在线看片| 99精品免费观看视频| av天堂中文字幕最新| 亚洲图片欧美校园春色| 国产午夜亚洲精品不卡在线观看| 欧美在线偷拍视频免费看| 黄色资源视频网站日韩| 日韩欧美一级精品在线观看| 青青伊人一精品视频| 欧美特级特黄a大片免费| av日韩在线观看大全| 国产老熟女伦老熟妇ⅹ| 天干天天天色天天日天天射| 亚洲 图片 欧美 图片| 色婷婷精品大在线观看| 在线观看免费视频色97| 2o22av在线视频| 天天干狠狠干天天操| 亚洲最大免费在线观看| 欧美熟妇一区二区三区仙踪林| 天天夜天天日天天日| 天天操天天射天天操天天天| 密臀av一区在线观看| 日韩二区视频一线天婷婷五| 午夜美女少妇福利视频| 日韩精品啪啪视频一道免费| 国产成人自拍视频播放 | 久草极品美女视频在线观看| 2021年国产精品自拍| 熟女视频一区,二区,三区| 精品亚洲国产中文自在线| 国产精品黄大片在线播放| 18禁美女黄网站色大片下载| 天天色天天操天天透| 香港一级特黄大片在线播放| 国产精品一区二区三区蜜臀av| 91小伙伴中女熟女高潮| 亚洲欧美激情国产综合久久久| 激情五月婷婷综合色啪| 色哟哟国产精品入口| 国产一区二区神马久久| 直接观看免费黄网站| 亚洲 欧美 自拍 偷拍 在线| 国产白嫩美女一区二区| 中字幕人妻熟女人妻a62v网| 亚洲av日韩精品久久久| 亚洲av午夜免费观看| gogo国模私拍视频| av完全免费在线观看av| 2017亚洲男人天堂| 亚洲Av无码国产综合色区| 东游记中文字幕版哪里可以看到| 欧美一区二区三区久久久aaa| 在线免费观看99视频| 国产福利小视频二区| 国产精品女邻居小骚货| 超pen在线观看视频公开97| 全国亚洲男人的天堂| 国产亚洲成人免费在线观看 | 女人精品内射国产99| 含骚鸡巴玩逼逼视频| 日本韩国免费一区二区三区视频| 免费69视频在线看| 亚洲av自拍天堂网| 精品久久久久久久久久中文蒉| 国产av一区2区3区| 国产成人精品久久二区91| 色哟哟在线网站入口| 熟女人妻在线中出观看完整版| 97人人妻人人澡人人爽人人精品| 91天堂天天日天天操| 国产熟妇一区二区三区av| 国产日本精品久久久久久久| 日本高清成人一区二区三区| 人妻无码色噜噜狠狠狠狠色| 青青热久免费精品视频在线观看| 久久香蕉国产免费天天| 国产一区二区火爆视频| 视频一区 视频二区 视频| 人妻熟女中文字幕aⅴ在线 | 免费男阳茎伸入女阳道视频 | 亚洲国产欧美国产综合在线| 初美沙希中文字幕在线| 日韩一区二区电国产精品| 午夜大尺度无码福利视频| 阿v天堂2014 一区亚洲| 五十路熟女人妻一区二| 性感美女高潮视频久久久| 日韩欧美在线观看不卡一区二区 | 亚洲va天堂va国产va久| 免费十精品十国产网站| 不戴胸罩引我诱的隔壁的人妻| 亚洲欧美成人综合视频| 国产刺激激情美女网站| 天天爽夜夜爽人人爽QC| 中文字幕最新久久久| 欧美性感尤物人妻在线免费看| 亚洲国产欧美一区二区三区久久| 极品性荡少妇一区二区色欲| 亚洲国产第一页在线观看| 国产成人一区二区三区电影网站| 被大鸡吧操的好舒服视频免费| 摧残蹂躏av一二三区| 蜜臀av久久久久久久| 国产精品久久久久久久久福交| 日韩欧美高清免费在线| 偷青青国产精品青青在线观看 | 一区二区三区 自拍偷拍| 天天艹天天干天天操| 男大肉棒猛烈插女免费视频| 深田咏美亚洲一区二区| 亚洲国产精品免费在线观看| 国内资源最丰富的网站| 亚洲欧美另类手机在线| 又大又湿又爽又紧A视频| 九九视频在线精品播放| 丝袜国产专区在线观看| 大学生A级毛片免费视频| 熟女人妻一区二区精品视频| 日韩欧美在线观看不卡一区二区 | 国产刺激激情美女网站| 视频 一区二区在线观看| 少妇人妻100系列| asmr福利视频在线观看| 亚洲一级美女啪啪啪| 91久久综合男人天堂| 欧美精品国产综合久久| 1000小视频在线| 最近中文字幕国产在线| 国产真实乱子伦a视频| 丝袜美腿欧美另类 中文字幕| 在线观看视频 你懂的| 国产使劲操在线播放| 亚洲欧美成人综合视频| 人妻丝袜精品中文字幕| 水蜜桃国产一区二区三区| 国产精品久久久久久美女校花| 一区二区三区欧美日韩高清播放| 337p日本大胆欧美人| 国产精品人妻66p| 国产精品久久久黄网站| 国产成人精品久久二区91| 天天做天天爽夜夜做少妇| 午夜福利资源综合激情午夜福利资| 91片黄在线观看喷潮| 国产精品探花熟女在线观看| 91九色porny蝌蚪国产成人| 日韩中文字幕在线播放第二页| 亚洲自拍偷拍精品网| 桃色视频在线观看一区二区 | 亚洲av日韩精品久久久| 久久热久久视频在线观看| 青青尤物在线观看视频网站| 一区二区视频在线观看免费观看| 在线免费观看99视频| 在线国产精品一区二区三区| 国产精选一区在线播放| 99久久中文字幕一本人| 99精品视频在线观看免费播放| 97小视频人妻一区二区| 国产视频一区二区午夜| 国产精品女邻居小骚货| 亚洲图片偷拍自拍区| 福利在线视频网址导航| 久久艹在线观看视频| AV无码一区二区三区不卡| 老师啊太大了啊啊啊尻视频| 日本一区美女福利视频| 日韩av免费观看一区| 中文字幕AV在线免费看 | 天天通天天透天天插| 性色蜜臀av一区二区三区| 久久久超爽一二三av| 亚洲熟女久久久36d| 色偷偷伊人大杳蕉综合网| 欧美国品一二三产区区别| 亚洲综合另类精品小说| 国产使劲操在线播放| 天天日天天透天天操| 天天做天天干天天舔| 男人的网址你懂的亚洲欧洲av| 中文 成人 在线 视频| 黄色三级网站免费下载| 在线观看av亚洲情色| 91免费黄片可看视频| 国产真实乱子伦a视频| 日韩欧美中文国产在线| 538精品在线观看视频| 91精品国产91久久自产久强| 日韩欧美国产一区ab| av手机免费在线观看高潮| 久久久久久久精品成人热| 激情人妻校园春色亚洲欧美 | 青青伊人一精品视频| 亚洲高清免费在线观看视频| 99久久成人日韩欧美精品| 国产内射中出在线观看| 国产片免费观看在线观看| 青青青青青青青青青青草青青| 狠狠地躁夜夜躁日日躁| 久久香蕉国产免费天天| 中国熟女一区二区性xx| 亚洲欧美成人综合视频| 青青草原色片网站在线观看| 亚洲欧美福利在线观看| 99国内小视频在现欢看| av手机在线观播放网站| 日韩精品中文字幕播放| 青青社区2国产视频| 日本韩国在线观看一区二区| 亚洲熟女女同志女同| 一区二区三区精品日本| 午夜久久久久久久99| 中文字幕亚洲久久久| 欧美一区二区中文字幕电影| 亚洲成人国产综合一区| 超级福利视频在线观看| 毛茸茸的大外阴中国视频| 啊慢点鸡巴太大了啊舒服视频| 91chinese在线视频| 国产又粗又黄又硬又爽| 91she九色精品国产| 亚洲福利午夜久久久精品电影网| 亚洲天堂第一页中文字幕| 国产精品一区二区av国| 亚洲精品国偷自产在线观看蜜桃| 爆乳骚货内射骚货内射在线| 精品一区二区三区午夜| 亚洲福利精品视频在线免费观看| 国产免费av一区二区凹凸四季| 国产1区,2区,3区| 中文字幕在线一区精品| 亚洲精品成人网久久久久久小说 | 老司机99精品视频在线观看 | 国产一级精品综合av| 青青热久免费精品视频在线观看| 色婷婷综合激情五月免费观看| 中文字幕在线免费第一页| 美女被肏内射视频网站| 干逼又爽又黄又免费的视频| 成人伊人精品色xxxx视频| 91p0rny九色露脸熟女| 韩国男女黄色在线观看| 亚洲 清纯 国产com| 中文亚洲欧美日韩无线码| 欧美激情电影免费在线| 无码中文字幕波多野不卡| 日韩a级黄色小视频| 日本女大学生的黄色小视频| 男人天堂av天天操| 老熟妇凹凸淫老妇女av在线观看| 成人色综合中文字幕| 亚洲图片偷拍自拍区| 色噜噜噜噜18禁止观看| 日韩特级黄片高清在线看| 日本裸体熟妇区二区欧美| 国产熟妇人妻ⅹxxxx麻豆| 日韩特级黄片高清在线看| 欧美视频综合第一页| 人妻少妇亚洲精品中文字幕| 视频一区二区综合精品| 欧美老妇精品另类不卡片| 99av国产精品欲麻豆| 岛国一区二区三区视频在线| 狠狠的往里顶撞h百合| 日韩美av高清在线| 天天摸天天干天天操科普| 国产普通话插插视频| av在线免费资源站| 成人动漫大肉棒插进去视频| 国产精品视频资源在线播放| 在线网站你懂得老司机| 中文字幕日韩精品就在这里| 精品乱子伦一区二区三区免费播| 久久机热/这里只有| 在线观看免费视频网| 精品欧美一区二区vr在线观看| 成年人午夜黄片视频资源| 中文字幕视频一区二区在线观看| 自拍偷区二区三区麻豆| 熟女俱乐部一二三区| 中国视频一区二区三区| eeuss鲁片一区二区三区| 成年人黄视频在线观看| 91免费观看国产免费| 啪啪啪啪啪啪啪啪av| 欧美一区二区三区啪啪同性| 美女福利视频导航网站 | 国产真实乱子伦a视频 | 天天夜天天日天天日| 一区二区三区四区视频在线播放| 久久永久免费精品人妻专区| 亚洲视频在线视频看视频在线| 一区二区三区麻豆福利视频| 香港三日本三韩国三欧美三级| 成人高潮aa毛片免费| 岛国黄色大片在线观看| 午夜场射精嗯嗯啊啊视频| 综合精品久久久久97| 亚洲福利午夜久久久精品电影网| 做爰视频毛片下载蜜桃视频1| 青青青青青手机视频| 色综合天天综合网国产成人| 久久永久免费精品人妻专区| 亚洲最大免费在线观看| caoporm超碰国产| 亚洲国产最大av综合| 美日韩在线视频免费看| 天天干天天操天天插天天日| 亚洲精品麻豆免费在线观看 | 日韩午夜福利精品试看| 欧美亚洲中文字幕一区二区三区| 天天综合天天综合天天网| 亚洲成人精品女人久久久| 国产va在线观看精品| 亚洲一区二区三区久久午夜| 亚洲一区二区人妻av| 五十路丰满人妻熟妇| 一区二区三区精品日本| 成人av免费不卡在线观看| 午夜美女福利小视频| 亚洲综合乱码一区二区| 首之国产AV医生和护士小芳| 又黄又刺激的午夜小视频| 国产极品美女久久久久久| 97青青青手机在线视频| 在线视频精品你懂的| 国产熟妇乱妇熟色T区| 自拍偷拍 国产资源| 大鸡吧插入女阴道黄色片| 国产中文精品在线观看| 日本人妻少妇18—xx| 久久久麻豆精亚洲av麻花| 亚洲av午夜免费观看| 成年午夜免费无码区| 日韩成人免费电影二区| 97香蕉碰碰人妻国产樱花| 亚洲午夜电影之麻豆| 国产女人被做到高潮免费视频 | 亚洲护士一区二区三区| 天天操天天插天天色| 福利一二三在线视频观看| 中文人妻AV久久人妻水| 唐人色亚洲av嫩草| 亚洲综合一区成人在线| 精品人人人妻人人玩日产欧| 日本熟女精品一区二区三区| 中文字幕av第1页中文字幕| 日本最新一二三区不卡在线| 国产高潮无码喷水AV片在线观看| 91免费观看国产免费| 五十路在线观看完整版| 欧美麻豆av在线播放| 成人伊人精品色xxxx视频| 午夜激情高清在线观看| 中文字幕av熟女人妻| 亚洲最大黄了色网站| www天堂在线久久| 精品一线二线三线日本| 2021天天色天天干| 久久精品亚洲成在人线a| 中文字幕av第1页中文字幕| 日韩人妻在线视频免费| 国产乱子伦精品视频潮优女| 精品国产污污免费网站入口自| 人妻在线精品录音叫床| 亚洲人人妻一区二区三区| 91精品一区二区三区站长推荐| 免费无码人妻日韩精品一区二区| 3D动漫精品啪啪一区二区下载| 日本一本午夜在线播放| 38av一区二区三区| 亚洲av无码成人精品区辽| 阿v天堂2014 一区亚洲| 91香蕉成人app下载| 中文亚洲欧美日韩无线码| 男生舔女生逼逼视频| 91超碰青青中文字幕| 天天色天天操天天舔| 国内资源最丰富的网站| 91高清成人在线视频| 97欧洲一区二区精品免费| 欧美成人一二三在线网| 91chinese在线视频| 亚洲午夜精品小视频| 精品人妻每日一部精品| 黄色在线观看免费观看在线| 大鸡八强奸视频在线观看| 91欧美在线免费观看| av大全在线播放免费| 在线视频自拍第三页| 搡老熟女一区二区在线观看| 日韩二区视频一线天婷婷五| 天天干狠狠干天天操| 日本av熟女在线视频| 亚洲国产欧美一区二区三区久久| 五月色婷婷综合开心网4438| 性生活第二下硬不起来| 人人爱人人妻人人澡39| 绝色少妇高潮3在线观看| 一区二区久久成人网| 91欧美在线免费观看| 久久永久免费精品人妻专区| 亚洲卡1卡2卡三卡四老狼| 伊人网中文字幕在线视频| 91九色porny蝌蚪国产成人| 日本美女性生活一级片| 国产黑丝高跟鞋视频在线播放 | 91色秘乱一区二区三区| 天天操天天干天天艹| 国产精品视频男人的天堂| 97少妇精品在线观看| 亚洲欧美国产综合777| 久青青草视频手机在线免费观看 | 国产精品自偷自拍啪啪啪| 亚洲va国产va欧美精品88| 青青草在观免费国产精品| 亚洲人妻30pwc| 91‖亚洲‖国产熟女| 97a片免费在线观看| 岛国免费大片在线观看| 动色av一区二区三区| 日本少妇在线视频大香蕉在线观看| 欧美一级片免费在线成人观看 | 欧美激情精品在线观看| av中文字幕电影在线看| 黄色黄色黄片78在线| 97超碰国语国产97超碰| 人妻熟女在线一区二区| 国产精品国产三级国产精东| 天天做天天干天天操天天射| 98视频精品在线观看| 性感美女福利视频网站| 亚洲国产香蕉视频在线播放| 啊啊好慢点插舔我逼啊啊啊视频| 蜜桃视频入口久久久| 888欧美视频在线| 国产伦精品一区二区三区竹菊| 亚洲欧美国产综合777| 亚洲一区久久免费视频| 久久精品久久精品亚洲人| 韩国男女黄色在线观看| 黄色视频在线观看高清无码| 18禁美女无遮挡免费| 日韩成人免费电影二区| 2020久久躁狠狠躁夜夜躁| 青青擦在线视频国产在线| 天天插天天色天天日| 天天插天天色天天日| 日本少妇精品免费视频| 在线观看视频污一区| 扒开让我视频在线观看| 亚洲欧美一区二区三区电影| 热思思国产99re| 最新日韩av传媒在线| 国产性色生活片毛片春晓精品| 视频 一区二区在线观看| 51精品视频免费在线观看| 在线免费91激情四射 | 久精品人妻一区二区三区| 成人24小时免费视频| 男女之间激情网午夜在线| 三上悠亚和黑人665番号| 亚洲va国产va欧美va在线| 91社福利《在线观看| 日本性感美女写真视频| 天天干天天日天天谢综合156| 香港一级特黄大片在线播放| 一级黄色av在线观看| 青青青国产免费视频| 天天色天天爱天天爽| 人妻凌辱欧美丰满熟妇| 亚洲福利天堂久久久久久| 99精品国产免费久久| 绝顶痉挛大潮喷高潮无码| 青娱乐最新视频在线| 热思思国产99re| 成人高清在线观看视频| 欧美精品久久久久久影院| 国产自拍黄片在线观看| 久久久麻豆精亚洲av麻花| 91高清成人在线视频| 最新91精品视频在线| 亚洲国产成人最新资源| 在线免费观看99视频| 偷拍自拍 中文字幕| 91小伙伴中女熟女高潮| yellow在线播放av啊啊啊| 狠狠躁夜夜躁人人爽天天天天97| 国产欧美日韩第三页| 亚洲av成人网在线观看| 中英文字幕av一区| 91国偷自产一区二区三区精品| 亚洲精品久久综合久| 国产一级精品综合av| 精品区一区二区三区四区人妻| 丰满的继坶3中文在线观看| 天天艹天天干天天操| 亚洲熟女综合色一区二区三区四区| 久久尻中国美女视频| 4个黑人操素人视频网站精品91| 日本脱亚入欧是指什么| 成人性爱在线看四区| 天天夜天天日天天日| 午夜成午夜成年片在线观看| 2021年国产精品自拍| 亚洲高清国产一区二区三区| 国产午夜福利av导航| 人妻丝袜诱惑我操她视频| 91免费福利网91麻豆国产精品| 国产a级毛久久久久精品| 成熟熟女国产精品一区| 3344免费偷拍视频| 91在线免费观看成人| 国产精品系列在线观看一区二区 | 天天做天天干天天舔| 国产综合视频在线看片| 在线播放 日韩 av| 丰满的子国产在线观看| 欧美3p在线观看一区二区三区| 欧洲欧美日韩国产在线| 国产亚洲四十路五十路| 中文字幕欧美日韩射射一| 少妇与子乱在线观看| 久草极品美女视频在线观看 | 欧洲日韩亚洲一区二区三区| 一二三区在线观看视频| 美女少妇亚洲精选av| www久久久久久久久久久| 人人人妻人人澡人人| 3344免费偷拍视频| 亚洲免费av在线视频| 9色在线视频免费观看| av网址在线播放大全| av手机在线免费观看日韩av| 首之国产AV医生和护士小芳| 欧美天堂av无线av欧美| 黄色视频在线观看高清无码| 国产女人被做到高潮免费视频| 国产一级麻豆精品免费| 欧美日韩一级黄片免费观看| 国产丰满熟女成人视频| 在线观看操大逼视频| 韩国一级特黄大片做受| 狍和女人的王色毛片| 在线播放 日韩 av| 大学生A级毛片免费视频| 国产综合视频在线看片| 久久久久五月天丁香社区| 人人在线视频一区二区| yellow在线播放av啊啊啊| 五十路熟女av天堂| 欧美爆乳肉感大码在线观看| 亚洲av琪琪男人的天堂| 亚洲天堂有码中文字幕视频| 一色桃子人妻一区二区三区| 蝴蝶伊人久久中文娱乐网 | 岛国av高清在线成人在线| 亚洲在线免费h观看网站| 久草视频在线一区二区三区资源站 | 国产日韩一区二区在线看 | 欧美日韩激情啪啪啪| 55夜色66夜色国产精品站| 久久尻中国美女视频| 动漫美女的小穴视频| 亚洲av第国产精品| 欧洲黄页网免费观看| 自拍偷拍亚洲另类色图| 三级等保密码要求条款| 久久热这里这里只有精品| 日本一二三区不卡无| 亚洲精品色在线观看视频| 欧美亚洲中文字幕一区二区三区| 天天操天天干天天艹| 日韩美女精品视频在线观看网站| 97人人妻人人澡人人爽人人精品| 97a片免费在线观看| 午夜久久香蕉电影网| 亚洲一级av无码一级久久精品| 18禁网站一区二区三区四区| 亚洲偷自拍高清视频| 国产成人综合一区2区| 人人妻人人澡人人爽人人dvl| 美女在线观看日本亚洲一区| 亚洲免费视频欧洲免费视频| 高清一区二区欧美系列| 伊人综合免费在线视频| 国产大学生援交正在播放| 91中文字幕免费在线观看| 93精品视频在线观看| 毛茸茸的大外阴中国视频| 日本熟妇一区二区x x| 久久www免费人成一看片| 大骚逼91抽插出水视频| 国产精品午夜国产小视频| 3344免费偷拍视频| 在线国产中文字幕视频| 青春草视频在线免费播放| 蜜桃臀av蜜桃臀av| 欧美久久一区二区伊人| 日韩精品中文字幕在线| 中文字幕在线欧美精品| 91精品国产综合久久久蜜| 亚洲 自拍 色综合图| 韩国亚洲欧美超一级在线播放视频 | 成人网18免费视频版国产| 在线观看亚洲人成免费网址| 在线国产日韩欧美视频| 欧美aa一级一区三区四区| 福利片区一区二体验区| 只有精品亚洲视频在线观看| 日韩欧美中文国产在线| 亚洲国产成人av在线一区| 精品一区二区三区欧美| 99热碰碰热精品a中文| 免费观看理论片完整版| 自拍偷拍亚洲欧美在线视频| 视频二区在线视频观看| 亚洲福利精品视频在线免费观看| 亚洲va国产va欧美va在线| 青青草精品在线视频观看| 亚洲av极品精品在线观看| 久久这里只有精品热视频 | 天天日天天鲁天天操| 激情小视频国产在线| 欧洲欧美日韩国产在线| 亚洲av极品精品在线观看| 亚洲欧美久久久久久久久| 天天干夜夜操天天舔| 日韩欧美高清免费在线| 中文字幕av男人天堂| 任你操视频免费在线观看| 日本五十路熟新垣里子| 国产精品国色综合久久| 亚洲av无码成人精品区辽| 午夜国产福利在线观看| 国产一区二区欧美三区| 蝴蝶伊人久久中文娱乐网| 国产乱弄免费视频观看| 最新中文字幕免费视频| 在线视频这里只有精品自拍| 久草极品美女视频在线观看| 扒开让我视频在线观看| 漂亮 人妻被中出中文| 高清成人av一区三区| 五十路熟女人妻一区二| 日本福利午夜电影在线观看| 亚洲国产在人线放午夜| 亚洲男人在线天堂网| 日韩中文字幕精品淫| 国产福利小视频免费观看| huangse网站在线观看| 老司机免费福利视频网| 青青草成人福利电影| 国产女人叫床高潮大片视频| 91久久人澡人人添人人爽乱| 超碰在线中文字幕一区二区| 全国亚洲男人的天堂| 日本少妇人妻xxxxxhd| av一本二本在线观看| 亚洲精品午夜久久久久| 美女 午夜 在线视频| 在线国产精品一区二区三区| 青青青aaaa免费| 成人sm视频在线观看| caoporm超碰国产| 51精品视频免费在线观看| 日本丰满熟妇大屁股久久| 亚洲综合一区成人在线| 欧美80老妇人性视频| 2018最新中文字幕在线观看| 国产真实灌醉下药美女av福利| 久久久久久性虐视频| 欧美亚洲牲夜夜综合久久| 97少妇精品在线观看| 日本韩国在线观看一区二区| 在线可以看的视频你懂的| 亚洲成人av在线一区二区| 日日夜夜大香蕉伊人| 视频在线亚洲一区二区| 97香蕉碰碰人妻国产樱花| 11久久久久久久久久久| 女警官打开双腿沦为性奴| 在线免费观看亚洲精品电影| 九色porny九色9l自拍视频| 97青青青手机在线视频 | 精品人妻一二三区久久| 亚洲av男人的天堂你懂的| av天堂中文字幕最新| 青青草原色片网站在线观看| tube69日本少妇| 欧美香蕉人妻精品一区二区| 好吊操视频这里只有精品| 中国熟女一区二区性xx| 高潮喷水在线视频观看| 中文字幕午夜免费福利视频| 欧洲亚洲欧美日韩综合| 快点插进来操我逼啊视频| 精品人妻一二三区久久| 最新黄色av网站在线观看| 在线观看911精品国产 | 色婷婷精品大在线观看| av中文字幕国产在线观看| 最新欧美一二三视频 | 天天操夜夜操天天操天天操| 青草亚洲视频在线观看| 唐人色亚洲av嫩草| 91免费放福利在线观看| 午夜场射精嗯嗯啊啊视频| 性生活第二下硬不起来| 91试看福利一分钟| 日韩精品电影亚洲一区| 欧洲亚洲欧美日韩综合| 极品性荡少妇一区二区色欲| 大屁股熟女一区二区三区| 激情啪啪啪啪一区二区三区 | av老司机精品在线观看| 日韩av中文在线免费观看| 久久久91蜜桃精品ad| 97色视频在线观看| 日韩精品电影亚洲一区| 日本少妇精品免费视频| 性欧美日本大妈母与子| 美女福利视频网址导航| 国产一级精品综合av| 亚洲国产成人av在线一区| 免费av岛国天堂网站| 97人妻色免费视频| 婷婷综合蜜桃av在线| 黄片三级三级三级在线观看| 偷拍自拍福利视频在线观看| 99热久久这里只有精品| 馒头大胆亚洲一区二区| av手机在线免费观看日韩av| 亚欧在线视频你懂的| 把腿张开让我插进去视频| 香港一级特黄大片在线播放| 亚洲va国产va欧美va在线| 日韩影片一区二区三区不卡免费| 亚洲综合在线观看免费| 免费看美女脱光衣服的视频| 亚洲女人的天堂av| 自拍 日韩 欧美激情| 亚洲特黄aaaa片| 国产黄色高清资源在线免费观看| 国产午夜亚洲精品麻豆| av手机在线免费观看日韩av| 亚洲av日韩av网站| 久碰精品少妇中文字幕av| 男女啪啪啪啪啪的网站| 自拍 日韩 欧美激情| 天天摸天天亲天天舔天天操天天爽| 天天操夜夜骑日日摸| 水蜜桃国产一区二区三区| 超黄超污网站在线观看| 91超碰青青中文字幕| 成人av电影免费版| 天天干天天日天天干天天操| 亚洲精品一区二区三区老狼| 5528327男人天堂| 国产精品中文av在线播放| 午夜精品久久久久麻豆影视| 99婷婷在线观看视频| 亚洲福利天堂久久久久久| 最新国产精品网址在线观看| 日韩三级黄色片网站| 天天射夜夜操综合网| 北条麻妃av在线免费观看| 婷婷色中文亚洲网68| 97色视频在线观看| 天美传媒mv视频在线观看| 欧美日韩国产一区二区三区三州| 亚洲av午夜免费观看| 国产精品黄色的av| 国产精品亚洲а∨天堂免| 中文字幕+中文字幕| 一个人免费在线观看ww视频| 日韩中文字幕福利av| 国产视频在线视频播放| 婷婷激情四射在线观看视频| 青青热久免费精品视频在线观看| 一区二区三区av高清免费| 91色秘乱一区二区三区| 丰满熟女午夜福利视频| 桃色视频在线观看一区二区| 国产丰满熟女成人视频| 日本阿v视频在线免费观看| 亚洲日本一区二区三区 | 在线免费观看国产精品黄色| 开心 色 六月 婷婷| 性色蜜臀av一区二区三区| 人人妻人人爽人人添夜| 99久久99一区二区三区| 美女福利写真在线观看视频| 91 亚洲视频在线观看| 视频一区 二区 三区 综合| 免费国产性生活视频| 涩涩的视频在线观看视频| 久久久久久九九99精品| 经典国语激情内射视频| 色狠狠av线不卡香蕉一区二区 | chinese国产盗摄一区二区| 快插进小逼里大鸡吧视频| 亚洲专区激情在线观看视频| 日韩成人免费电影二区| av中文字幕福利网| 日本脱亚入欧是指什么| 午夜精品久久久久久99热| 男人操女人的逼免费视频| 一级黄色av在线观看| 亚洲综合一区成人在线| 老司机福利精品视频在线| 老有所依在线观看完整版| 人妻无码中文字幕专区| 91在线免费观看成人| 91国产在线视频免费观看| 国产女孩喷水在线观看| 国产黑丝高跟鞋视频在线播放| 黄片色呦呦视频免费看| 亚洲天堂av最新网址| 97资源人妻免费在线视频| 中文字幕,亚洲人妻| 美女骚逼日出水来了| 巨乳人妻日下部加奈被邻居中出| av俺也去在线播放| 91免费观看在线网站| 国产妇女自拍区在线观看| 欧美天堂av无线av欧美| 国产一区自拍黄视频免费观看| 男人操女人逼逼视频网站| 在线播放 日韩 av| 丰满少妇翘臀后进式| 特级无码毛片免费视频播放| 中文字幕日韩无敌亚洲精品 | 精品一区二区三区在线观看| 瑟瑟视频在线观看免费视频| 欧美综合婷婷欧美综合| 日韩二区视频一线天婷婷五| 一区二区在线视频中文字幕| 久草视频首页在线观看| 国产免费高清视频视频| 欧美viboss性丰满| 大鸡八强奸视频在线观看| 亚洲激情偷拍一区二区| 99久久中文字幕一本人| 一区二区三区激情在线| 91p0rny九色露脸熟女| 91麻豆精品91久久久久同性| 日本黄色三级高清视频| 国产av自拍偷拍盛宴| 国产视频精品资源网站| 综合精品久久久久97| 午夜国产免费福利av| 这里只有精品双飞在线播放| 青青青青青青青在线播放视频| 久久久久久cao我的性感人妻| 啪啪啪啪啪啪啪啪啪啪黄色| 插逼视频双插洞国产操逼插洞| 国产麻豆乱子伦午夜视频观看| 91www一区二区三区| 亚洲2021av天堂| 久久永久免费精品人妻专区| 国产品国产三级国产普通话三级| 狠狠的往里顶撞h百合| 国产午夜激情福利小视频在线| 天天色天天爱天天爽| 欧美aa一级一区三区四区| 国产精品久久久久久美女校花| 精品黑人一区二区三区久久国产 | 人妻少妇性色欲欧美日韩| 国产欧美日韩在线观看不卡| 综合色区亚洲熟妇shxstz| 日本男女操逼视频免费看| 伊人成人综合开心网| 日本乱人一区二区三区| 日韩一区二区三区三州| 中文字幕av第1页中文字幕| 亚洲av自拍天堂网| 少妇高潮无套内谢麻豆| 欧美日韩熟女一区二区三区| 夜夜骑夜夜操夜夜奸| 男女之间激情网午夜在线| 国产精品黄大片在线播放| 中文字幕日韩精品日本| av网址在线播放大全| 顶级尤物粉嫩小尤物网站| 国产视频一区在线观看| 真实国模和老外性视频| 国产成人精品久久二区91| 91综合久久亚洲综合| 国产黄色大片在线免费播放| 福利午夜视频在线合集| 99av国产精品欲麻豆| 熟女人妻在线中出观看完整版| 亚洲国产成人无码麻豆艾秋| 在线免费观看视频一二区| 粉嫩av蜜乳av蜜臀| 亚洲精品国产综合久久久久久久久| 亚洲福利精品视频在线免费观看| 99re6热在线精品| 九色视频在线观看免费| 亚洲 自拍 色综合图| 夏目彩春在线中文字幕| 91香蕉成人app下载| 久久久久五月天丁香社区| 亚洲av自拍天堂网| 国产在线拍揄自揄视频网站| av在线播放国产不卡| 国产精彩对白一区二区三区| 一区二区久久成人网| 男女啪啪视频免费在线观看 | 国产日韩精品一二三区久久久| 精内国产乱码久久久久久| 91精品免费久久久久久| 国产自拍在线观看成人| 久久精品36亚洲精品束缚| 97超碰国语国产97超碰| 不卡一区一区三区在线| 亚洲成人三级在线播放| 91麻豆精品秘密入口在线观看| 秋霞午夜av福利经典影视| 精品区一区二区三区四区人妻| 日本黄色三级高清视频| 最新黄色av网站在线观看| 九色精品视频在线播放| 又粗又硬又猛又爽又黄的| 国产密臀av一区二区三| 欧美精品亚洲精品日韩在线| 国产黑丝高跟鞋视频在线播放| 亚洲国产40页第21页| 美女视频福利免费看|