国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

索引為什么能提高查詢性能....

運(yùn)維 數(shù)據(jù)庫運(yùn)維
昨天,有個(gè)女孩子問我提高數(shù)據(jù)庫查詢性能有什么立竿見影的好方法?這簡直是一道送分題,我自豪且略帶鄙夷的說,當(dāng)然是加「索引」了。

 [[354356]]

本文轉(zhuǎn)載自微信公眾號(hào)「小林coding」,作者木葉瀟瀟。轉(zhuǎn)載本文請(qǐng)聯(lián)系小林coding公眾號(hào)。  

前言

昨天,有個(gè)女孩子問我提高數(shù)據(jù)庫查詢性能有什么立竿見影的好方法?

這簡直是一道送分題,我自豪且略帶鄙夷的說,當(dāng)然是加「索引」了。

她又不緊不慢的問,索引為什么就能提高查詢性能。

這還用問,索引就像一本書的目錄,用目錄查當(dāng)然很快。

她失望地?fù)u了搖頭,你說的只是一個(gè)類比,可為什么通過目錄就能提高查詢速度呢。

唉,對(duì)啊,通過書目可以快速查詢,這只是一個(gè)現(xiàn)象,真正原因到底是什么呢。

那女孩看著詫異且表情僵硬的我,滿意而又意味深長的笑笑:原來你這個(gè)男程序員也不會(huì),看來我還得靠自己研究了。

哎,熬夜又要憔悴了我這該死的美貌。

來自同行的羞辱,是可忍孰不可忍?!

于是,我踏上了數(shù)據(jù)庫索引學(xué)習(xí)的不歸路,原來數(shù)據(jù)庫索引使用了一種叫 B+ 樹的古老數(shù)據(jù)結(jié)構(gòu),當(dāng)然也有 Hash 等類型,暫且不說,可 B+ 樹 這是個(gè)什么妖魔鬼怪呢?

下面就來淺嘗輒止的扒一扒樹的前世今生。

正文

二叉樹

由 n( n > 0)個(gè)有限節(jié)點(diǎn)組成一個(gè)具有層次關(guān)系的集合,看起來就像一個(gè)倒掛的樹,因此稱這樣的數(shù)據(jù)結(jié)構(gòu)為樹。

一個(gè)節(jié)點(diǎn)的子節(jié)點(diǎn)個(gè)數(shù)叫做度,通俗的講就是樹叉的個(gè)數(shù)。樹中最大的度叫做樹的度,也叫做階。一個(gè) 2 階樹最多有 2 個(gè)子節(jié)點(diǎn)即最多有 2 叉,因此這樣的樹稱為二叉樹,二叉樹是樹家族中最簡單的樹。

兩個(gè)叉的樹就是二叉樹,可這除了用來按一定結(jié)構(gòu)存放數(shù)據(jù)外,跟查詢性能好像也沒關(guān)系,不會(huì)又是一個(gè)沒用的噱頭吧。

二分查找

聽說二叉樹的原始威力來源于一種叫做二分查找的算法。

相傳在鸚鵡的原始社會(huì),存在著森嚴(yán)的等級(jí)制度,每只鳥必須按高矮順序分出等級(jí)和尊卑。

那么問題來了,如下圖,怎樣才能找出最高、最矮、中等高的那些鸚鵡呢、以及指定高度的那只呢?

第一種方法: 掃描法

一個(gè)一個(gè)依次測量,完畢后所有的問題都迎刃而解。

這種一個(gè)一個(gè)依次全部測量的方法叫做掃描,他的缺點(diǎn)很明顯,最高和最矮,需要全部測量完畢才能知曉。

而對(duì)于指定高度,最好的情況是第一次就找到;最壞的情況是最后一次才找到,時(shí)間復(fù)雜度為 n,也就是說從 13 個(gè)鸚鵡中找到指定身高的那只,最壞的情況是查 13 次。

第二種方法:二分法

13 個(gè)鸚鵡全部聽令,按從矮到高列隊(duì),向左看齊,報(bào)數(shù)。

[[354358]]

報(bào)數(shù)字 1 的就是最矮的,報(bào)數(shù)字 13 的就是最高的,報(bào)數(shù)字 7 的就是中等身高的那只。

最好和最壞的情況都是一次找到。而查詢性能一下子提高 13 倍,我的個(gè)乖乖,無論多個(gè)只鸚鵡,時(shí)間復(fù)雜度都是 1,好可怕。

問題:我不服,你這是偷換概念,有本事對(duì)比一個(gè)查找指定高度鸚鵡的性能。

因?yàn)辂W鵡們已經(jīng)按高矮排好了隊(duì),所以指定高度的鸚鵡,要么是站中間那個(gè)只,要么就是在它的左邊或右邊的那群里。

如果是中間那個(gè),一次就找到,如果不是只需要從中間左邊或右邊那一半中找,再在這一半中找中間那只,對(duì)比身高。

以此類推,每次都把查詢的范圍減半,時(shí)間復(fù)雜度log2(n)。

那么 log2(13) 就是 4,最壞的情況也才 4 次,時(shí)間復(fù)雜度確實(shí)不是 1 了,但好像也不糟,簡化如下:

問題:如果按高矮排隊(duì),仍然需要一個(gè)一個(gè)比較,跟掃描有什么區(qū)別,那還不如直接掃描呢?

事實(shí)確實(shí)如此,單純的一次查詢,先排序,再二分查找,不見得比掃描快,甚至還不如。

但是,在數(shù)據(jù)的世界,大部分?jǐn)?shù)據(jù)一生會(huì)被查詢無數(shù)次,如果只在數(shù)據(jù)降生的時(shí)候排一次序,往后余生,是不是就可以直接用二分查找,這似乎就是傳說的讀多寫少,以及對(duì)應(yīng)的復(fù)用。

優(yōu)點(diǎn):

查找快

缺點(diǎn):

  • 必須有序,需要提前排序
  • 每次查找都需要不斷計(jì)算中間位置

二分查找樹

如果一組數(shù)據(jù)不會(huì)或不常變更,那么他們的位置也基本不變。可是每次查詢都需要重新計(jì)算中間位置是一種浪費(fèi),而浪費(fèi)可恥。

我們能不能把所有中間節(jié)點(diǎn)組織起來,每次使用時(shí),直接取中間節(jié)點(diǎn)?

請(qǐng)看下圖,找到所有單次二分查找的中間節(jié)點(diǎn),把他們連起來,并用手提起最中間的那個(gè)節(jié)點(diǎn),就是一棵二分查找樹。

優(yōu)點(diǎn):二分查找樹就是通過數(shù)據(jù)結(jié)構(gòu)的方式實(shí)現(xiàn)了二分查找算法,通過存儲(chǔ)中間節(jié)點(diǎn)的數(shù)據(jù),彌補(bǔ)了二分查找每次都要計(jì)算中間位置的缺點(diǎn)。

平衡二叉樹:

如果二分查找樹不斷進(jìn)行修改,比如刪除某些節(jié)點(diǎn),經(jīng)過一段時(shí)間后,最早那個(gè)中間節(jié)點(diǎn)的數(shù)據(jù)(根),很可能就不在中間了。

中間位置就像一個(gè)天平的支點(diǎn),如果他不在中間了,那么整個(gè)天平就會(huì)失衡,失衡的世界就會(huì)坍塌成不倫不類的瘸樹,甚至是降維成一個(gè)鏈表或者數(shù)組。

二分查找算法的關(guān)鍵在于有序和中間節(jié)點(diǎn),而二分查找樹的關(guān)鍵是中間節(jié)點(diǎn)的維護(hù),如果維護(hù)的節(jié)點(diǎn)已經(jīng)不在中間了,那么它就失去了意義。

所以必須保證「二分查找樹」是一個(gè)正確的樹,一個(gè)根節(jié)點(diǎn)在中心的樹,一個(gè)左右子樹層級(jí)(高度)基本相等(高度相差不超過1)的樹,一個(gè)平衡的樹。

平衡二叉樹中最常見的就是紅黑樹:

紅黑樹規(guī)定了一系列節(jié)點(diǎn)顏色規(guī)則,以及對(duì)應(yīng)的左旋和右旋操作來保證顏色規(guī)則,從而達(dá)到樹的平衡性。

看到這花里胡哨的顏色以及復(fù)雜的規(guī)則,讓人第一眼就望而卻步,但所有的這些,也不過是為了保證二叉樹的平衡性,由于維持平衡的操作太過麻煩,無法用一句話簡單概括,只好用一堆人鬼難分的規(guī)則和步驟來實(shí)現(xiàn),只要按著這些步驟就一定能實(shí)現(xiàn)二叉樹的平衡。

平衡二叉樹 = 二分查找樹 + 平衡(左右高度相差不超過 1 )

平衡二叉樹并未提高二分查找樹的性能,它只是保正樹不會(huì)被二向箔(多次增刪改)打擊降維成鏈表或不對(duì)稱的殘缺樹,永遠(yuǎn)維持平衡。

另外,不僅僅是二叉樹,其他種類的樹,也是需要有序和平衡,才能發(fā)揮最大的威力。

多叉樹之 B-tree

兩個(gè)叉的樹就能折半查詢,理論可以提高一倍性能,那么多個(gè)叉是不是能提高更多倍性能?

如下圖的 3 階(叉)樹(所有數(shù)據(jù)僅用于演示,非真實(shí)分布)

每個(gè)節(jié)點(diǎn)維護(hù)兩個(gè)數(shù)據(jù),并指向最多 3 個(gè)子節(jié)點(diǎn)。如圖 3 個(gè)子節(jié)點(diǎn)的數(shù)據(jù)分別為:小于 17, 17 ~ 35 ,大于 35。

假設(shè),從上圖中查找 10 這個(gè)數(shù),步驟如下:

  1. 找到根節(jié)點(diǎn),對(duì)比 10 與 17 和 35 的大小,發(fā)現(xiàn) 10 < 17 在左子節(jié)點(diǎn),也就是第 2 層節(jié)點(diǎn);
  2. 從根節(jié)點(diǎn)的指針,找到左子節(jié)點(diǎn),對(duì)比 10 與 8 和 12 的大小,發(fā)現(xiàn) 8 < 10 < 12,數(shù)據(jù)在當(dāng)前節(jié)點(diǎn)的中間子節(jié)點(diǎn),也就是第 3 層節(jié)點(diǎn);
  3. 通過上步節(jié)點(diǎn)的指針,找到中間子節(jié)點(diǎn)(第 3 層節(jié)點(diǎn)),對(duì)比 10 與 9 和 10 的大小,發(fā)現(xiàn) 9 < 10 == 10,因此找到當(dāng)前節(jié)點(diǎn)的第二數(shù)即為結(jié)果。

加上忽略的 12 個(gè)數(shù)據(jù),從 26 個(gè)數(shù)據(jù)中查找一個(gè)數(shù)字 10,僅僅用了 log3(26)≈ 3 次,而如果用平衡二叉樹,則需要 log2(26)≈ 5 次,事實(shí)證明,多叉樹確實(shí)可以再次提高查找性能。

多叉樹是在二分查找樹的基礎(chǔ)上,增加單個(gè)節(jié)點(diǎn)的數(shù)據(jù)存儲(chǔ)數(shù)量,同時(shí)增加了樹的子節(jié)點(diǎn)數(shù),一次計(jì)算可以把查找范圍縮小更多。

優(yōu)點(diǎn):二叉平衡樹的基礎(chǔ)上,使加載一次節(jié)點(diǎn),可以加載更多路徑數(shù)據(jù),同時(shí)把查詢范圍縮減到更小。

復(fù)雜節(jié)點(diǎn):

至此,我們列舉的數(shù)據(jù)都是孤零零的單個(gè)數(shù)字。試想,你手里已經(jīng)有一個(gè)數(shù)據(jù) 10,為什么還要費(fèi)力吧唧的再從一堆數(shù)據(jù)中找到這個(gè) 10,自己找自己?這不是有病嗎?

單個(gè)數(shù)字只能活在演示中,現(xiàn)實(shí)的世界要復(fù)雜的多,我們來看一個(gè)接近真實(shí)場景的案例。

現(xiàn)有一個(gè)以年齡為索引的 3 階樹,存儲(chǔ)了一批用戶信息,如下圖:

數(shù)字為用戶的年齡,其它為與樹排序查找無關(guān)的業(yè)務(wù)數(shù)據(jù),像這種索引數(shù)據(jù)與樹排序查找無關(guān)的業(yè)務(wù)一起維護(hù)在節(jié)點(diǎn)的平衡多叉(階)樹稱為 B- 樹( B 樹)。

缺點(diǎn):業(yè)務(wù)數(shù)據(jù)的大小可能遠(yuǎn)遠(yuǎn)超過了索引數(shù)據(jù)的大小,每次為了查找對(duì)比計(jì)算,需要把數(shù)據(jù)加載到內(nèi)存以及 CPU 高速緩存中時(shí),都要把索引數(shù)據(jù)和無關(guān)的業(yè)務(wù)數(shù)據(jù)全部查出來。本來一次就可以把所有索引數(shù)據(jù)加載進(jìn)來,現(xiàn)在卻要多次才能加載完。如果所對(duì)比的節(jié)點(diǎn)不是所查的數(shù)據(jù),那么這些加載進(jìn)內(nèi)存的業(yè)務(wù)數(shù)據(jù)就毫無用處,全部拋棄。

磁盤I/O

計(jì)算機(jī)的功能主要為:計(jì)算、存儲(chǔ)和網(wǎng)絡(luò)。而用于計(jì)算的數(shù)據(jù)以及計(jì)算后的結(jié)果很大一部分都需要存儲(chǔ)起來,以備后續(xù)再次使用。向磁盤中存儲(chǔ)和讀取的過程叫磁盤 I/O。磁盤的讀取方式和速度會(huì)嚴(yán)重影響到整個(gè)業(yè)務(wù)的計(jì)算性能。

下面我們簡單了解一下磁盤是如何工作的。

磁盤大概長這個(gè)樣子:

磁盤主要由磁盤盤片、傳動(dòng)手臂、讀寫磁頭和馬達(dá)組成。

為了存儲(chǔ)容量,主軸像穿糖葫蘆一樣把多個(gè)磁盤片組成一個(gè)陣列。通過馬達(dá)驅(qū)動(dòng)主軸轉(zhuǎn)動(dòng)以及傳動(dòng)手臂移動(dòng),使讀寫磁頭在磁盤片上讀寫數(shù)據(jù)。大概如下:

磁盤片由很多半徑不等的同心圓組成,這些圓被稱為磁道,數(shù)據(jù)就是寫在這些磁道上。

[[354363]]

每個(gè)磁道又劃分成塊稱為扇區(qū)。

如果磁盤是一記事本,那么一張磁盤片就是本子的一頁紙,而主軸就是本子的裝訂線;磁道就是紙頁的行,而扇區(qū)可以看作是很寬的列。

如果在磁盤中存儲(chǔ)一首詩,想象中大概這個(gè)樣子。

磁盤的讀 I/O 操作,需要找到數(shù)據(jù)所在的磁盤片,以及對(duì)應(yīng)的磁道和扇區(qū)。這些操作類似于從一本書中找到數(shù)據(jù)所在的頁,行,列。

因?yàn)槊總€(gè)磁盤片都對(duì)應(yīng)一個(gè)磁頭,所以性能的關(guān)鍵就在于找行和列,即尋道和磁盤旋轉(zhuǎn)。尋道即通過磁頭找到數(shù)據(jù)所在的磁道,相當(dāng)于換行到數(shù)據(jù)所在行。由于磁頭只能水平移動(dòng),即只能換行尋道,無法在指定磁道上移動(dòng),因此需要磁盤高速旋轉(zhuǎn)移動(dòng)到指定扇區(qū),類似寫春聯(lián)時(shí),筆不動(dòng),紙動(dòng)。

綜上所述,磁盤的讀寫是通過機(jī)械運(yùn)動(dòng)來定位數(shù)據(jù)所在位置,而 cpu 是通過電信號(hào)進(jìn)行數(shù)字運(yùn)算。粗略的認(rèn)為,機(jī)械查詢數(shù)據(jù),與光速處理數(shù)據(jù)的性能完全不是在一個(gè)量級(jí),總之一句話就是磁盤處理太慢太慢了。

雖然磁盤處理數(shù)據(jù)太慢了,但是它是目前相對(duì)廉價(jià)且穩(wěn)定的存儲(chǔ)設(shè)備,所以又不能舍棄不用,但大致可以通過以下方法進(jìn)行優(yōu)化。

  • 盡量減少 I/O 次數(shù),比如可以使用緩存;
  • 每次 I/O 盡量獲取更多的數(shù)據(jù);
  • 每次 I/O 盡量獲取有用的數(shù)據(jù),當(dāng)然相應(yīng)的也間接減少總 I/O 次數(shù);

多叉樹之 B+tree

做為數(shù)據(jù)庫的索引,無論用什么樣的數(shù)據(jù)結(jié)構(gòu)維護(hù),這些數(shù)據(jù)最終都會(huì)存儲(chǔ)到磁盤中。

鑒于磁盤 I/O 的性能問題,以及每次 I/O 獲取數(shù)據(jù)量上限所限,提高索引本身 I/O 的方法最好是,減少 I/O 次數(shù)和每次獲取有用的數(shù)據(jù)。

B-tree 已經(jīng)大大改進(jìn)了樹家族的性能,它把多個(gè)數(shù)據(jù)集中存儲(chǔ)在一個(gè)節(jié)點(diǎn)中,本身就可能減少了 I/O 次數(shù)或者尋道次數(shù)。

但是仍然有一個(gè)致命的缺陷,那就是它的索引數(shù)據(jù)與業(yè)務(wù)綁定在一塊,而業(yè)務(wù)數(shù)據(jù)的大小很有可能遠(yuǎn)遠(yuǎn)超過了索引數(shù)據(jù),這會(huì)大大減小一次 I/O 有用數(shù)據(jù)的獲取,間接的增加 I/O 次數(shù)去獲取有用的索引數(shù)據(jù)。

因?yàn)闃I(yè)務(wù)數(shù)據(jù)才是我們查詢最終的目的,但是它又是在「二分」查找中途過程無用的數(shù)據(jù),因此,如果只把業(yè)務(wù)數(shù)據(jù)存儲(chǔ)在最終查詢到的那個(gè)節(jié)點(diǎn)是不是就可以了?

理想很豐滿,現(xiàn)實(shí)很骨瘦如柴,誰知道哪個(gè)節(jié)點(diǎn)就是最終要查詢的節(jié)點(diǎn)呢?

B+tree 橫空出世,B+ 樹就是為了拆分索引數(shù)據(jù)與業(yè)務(wù)數(shù)據(jù)的平衡多叉樹。

B+ 樹中,非葉子節(jié)點(diǎn)只保存索引數(shù)據(jù),葉子節(jié)點(diǎn)保存索引數(shù)據(jù)與業(yè)務(wù)數(shù)據(jù)。這樣即保證了葉子節(jié)點(diǎn)的簡約干凈,數(shù)據(jù)量大大減小,又保證了最終能查到對(duì)應(yīng)的業(yè)務(wù)數(shù)。既提高了單次 I/O 數(shù)據(jù)的有效性,又減少了 I/O 次數(shù),還實(shí)現(xiàn)了業(yè)務(wù)。

但是,在數(shù)據(jù)中索引與數(shù)據(jù)是分離的,不像示例那樣的?

如圖:我們只需要把真實(shí)的業(yè)務(wù)數(shù)據(jù),換成數(shù)據(jù)所在地址就可以了,此時(shí),業(yè)務(wù)數(shù)據(jù)所在的地址在 B+ 樹中充當(dāng)業(yè)務(wù)數(shù)據(jù)。

總結(jié)

數(shù)據(jù)存儲(chǔ)在磁盤( SSD 跟 CPU 性能也不在一個(gè)量級(jí)),而磁盤處理數(shù)據(jù)很慢;

提高磁盤性能主要通過減少 I/O 次數(shù),以及單次 I/O 有效數(shù)據(jù)量;

索引通過多階(一個(gè)節(jié)點(diǎn)保存多個(gè)數(shù)據(jù),指向多個(gè)子節(jié)點(diǎn))使樹的結(jié)構(gòu)更矮胖,從而減少 I/O 次數(shù);

索引通過 B+ 樹,把業(yè)務(wù)數(shù)據(jù)與索引數(shù)據(jù)分離,來提高單次 I/O 有效數(shù)據(jù)量,從而減少 I/O 次數(shù);

索引通過樹數(shù)據(jù)的有序和「二分查找」(多階樹可以假設(shè)為多分查找),大大縮小查詢范圍;

索引針對(duì)的是單個(gè)字段或部分字段,數(shù)據(jù)量本身比一條記錄的數(shù)據(jù)量要少的多,這樣即使通過掃描的方式查詢索引也比掃描數(shù)據(jù)庫表本身快的多;

知識(shí)擴(kuò)展

樹的結(jié)構(gòu)最大的優(yōu)點(diǎn)就是查詢性能高,因此所有需要提高查詢性能的都可以考慮樹。

而現(xiàn)實(shí)中也確實(shí)有這樣的例子,比如:

HashMap 中的數(shù)據(jù)沖突時(shí),鏈表轉(zhuǎn)化成紅黑樹;

數(shù)據(jù)庫索引使用的 B+ 樹;

搜索引擎倒排索引使用的字典樹;

以上只是淺嘗輒止、點(diǎn)到為止的描述了數(shù)據(jù)庫使用 B+ 樹索引為什么能提高查詢性能原因及簡單過程。

并沒有深入各種數(shù)據(jù)結(jié)構(gòu)的細(xì)節(jié),也未提及其它索引類型和索引的具體存儲(chǔ)格式,目的僅僅是,為了讓大家對(duì)索引有一個(gè)感性的認(rèn)識(shí)。

原文鏈接:https://mp.weixin.qq.com/s/KxSlNnXQSaMemYdqyRCMOg

 

責(zé)任編輯:武曉燕 來源: 小林coding
相關(guān)推薦

2010-06-11 17:13:34

MySQL表索引

2020-12-11 08:02:16

索引MySQL存儲(chǔ)

2018-01-30 08:47:46

存儲(chǔ)查詢性能

2022-04-16 14:20:29

MySQL數(shù)據(jù)庫

2020-10-29 09:19:11

索引查詢存儲(chǔ)

2020-03-05 16:55:56

索引數(shù)據(jù)庫SQL

2011-08-16 13:27:34

索引

2011-08-15 18:20:05

建立索引SQL Sever數(shù)據(jù)

2020-08-10 11:20:59

索引MySQL數(shù)據(jù)庫

2020-09-07 10:23:01

MySQL索引查詢

2021-10-25 08:49:32

索引數(shù)據(jù)庫MySQL

2010-10-25 10:55:11

Oracle函數(shù)索引

2024-03-29 08:10:43

索引失效SQL

2009-05-12 13:10:22

OracleMySQLSELECT

2011-04-02 13:37:05

SQL Server 索引視圖

2011-04-01 15:36:24

索引SQL Server

2019-09-19 16:59:04

數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)數(shù)據(jù)庫

2011-03-17 14:48:49

高級(jí)掃描數(shù)據(jù)庫查詢

2012-08-15 09:41:28

虛擬化

2021-12-13 01:40:29

ElasticSear倒排索引
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美大片在线影院| 91影视免费在线观看| 免费国产在线视频| 中文幕一区二区三区久久蜜桃| 欧美日韩免费高清| 国产一区视频在线观看免费| 国产精品一区专区欧美日韩| 成人h动漫精品一区二区器材| 最近2019中文字幕一页二页 | 国产精品一级片在线观看| 婷婷五月在线视频| 欧美日韩综合| 国产午夜精品全部视频播放 | 在线观看日韩av先锋影音电影院| 亚洲高清视频一区二区| 郴州新闻综合频道在线直播| 久久的精品视频| 韩国主播福利视频一区二区三区| 欧美天天综合色影久久精品| 开心丁香婷婷深爱五月| 日韩美女啊v在线免费观看| 亚洲精品中字| 国产精品乱看| 超碰91人人草人人干| 国产极品人妖在线观看| 国产亚洲短视频| 国产精彩视频一区二区| 久久精品高清| 国产精品久久久久桃色tv| 性欧美18一19内谢| 国产成人综合在线观看| 国产91在线视频观看| 成人欧美一区二区三区白人 | 二区三区四区高清视频在线观看| 一本色道久久综合亚洲精品按摩| 你懂的视频在线免费| 欧美日韩高清一区二区三区| 精品捆绑调教一区二区三区| 久久国产精品首页| 精品久久久久久久久久久aⅴ| 国产呦系列欧美呦日韩呦| 奇米色一区二区三区四区| 欧洲金发美女大战黑人| 一区二区三区免费观看| √天堂8资源中文在线| 欧美tickling挠脚心丨vk| a毛片不卡免费看片| 日本精品久久久久影院| 久久久久网站| 国产精品www在线观看| 一区二区三区在线不卡| 男女视频在线| 国产免费久久av| 97精品国产露脸对白| 男女网站在线观看| 午夜精品久久久久久久久久久久| 狠狠色丁香久久综合频道| 欧美精品成人一区二区在线观看| 奇米888四色在线精品| 三上悠亚在线一区二区| 欧洲亚洲国产日韩| aaa在线观看| 性欧美办公室18xxxxhd| 国产麻豆精品久久一二三| 三上悠亚一区| 久久色在线播放| 中文在线不卡| 一级毛片视频在线观看| 国产精品免费在线播放| 亚洲国产电影| 米奇精品一区二区三区在线观看| 天天免费亚洲黑人免费| 欧美一区2区三区4区公司二百| 亚洲第一福利一区| a级日韩大片| 色婷五月综激情亚洲综合| 久久精品免费播放| 久久狠狠亚洲综合| 中文字幕欧美一区二区| 国产成人精品电影| 亚洲欧洲在线观看av| 成人知道污网站| 国产精品专区在线| 久久av中文字幕| 亚洲欧美日韩久久| 人人精品视频| 亚洲第一成年免费网站| 国产精品露脸av在线| 午夜激情久久久| 精品国产99| 在线天堂av| 欧美亚洲另类制服自拍| 国产婷婷色一区二区三区四区| 成人全视频免费观看在线看| 毛片av免费在线观看| 国产精品视频99| 91精品国产综合久久精品麻豆| 在线观看一区视频| 国产黄色小视频在线| 日韩亚洲欧美视频| 91国产精品91| 欧美男生操女生| 久久久av毛片精品| 国产不卡一区| 欧美男男video| 毛片av免费在线观看| 97av在线播放| 精品电影一区二区| 亚洲综合色婷婷| 日韩国产欧美视频| 亚洲97av| 羞羞的视频在线观看| jizz欧美性11| 日本婷婷久久久久久久久一区二区| 精品日韩欧美在线| 久久先锋资源网| 日本在线不卡视频| 欧美一区二区三区红桃小说| 日韩av片网站| 色综合天天综合给合国产| 久久美女精品| 成人免费一区二区三区牛牛| 秋霞福利视频| 影音先锋男人的网站| 国产欧美久久一区二区| 欧美另类暴力丝袜| 中文字幕视频一区二区在线有码| 亚洲欧美激情在线| 国产黑丝在线一区二区三区| 欧美网站在线| 91精品成人| 亚洲三级国产| 亚洲一区欧美| 羞羞答答一区二区| 中文字幕这里只有精品| 成年人在线观看视频免费| 亚洲欧美日韩另类精品一区二区三区| 国产精品wwwwww| 国产精品久久久久久久av电影| 色婷婷av一区二区三区gif| 亚洲精品国产成人久久av盗摄| 欧美激情在线一区二区三区| 久久激五月天综合精品| 九九九久久久精品| 免费在线亚洲| 首页亚洲欧美制服丝腿| 久久久青草婷婷精品综合日韩 | 97在线中文字幕| 欧美精品video| 欧美在线观看网站| 午夜精品视频网站| 欧美成年人视频| 精品国产一区久久久| 国产亚洲欧美视频| 亚洲精品丝袜日韩| 亚洲欧洲日韩国产| 夜夜嗨av色综合久久久综合网| 日韩写真欧美这视频| 91精品国产欧美日韩| 亚洲国产日韩欧美在线动漫| 在线成人免费网站| 国产精品极品美女粉嫩高清在线| av噜噜色噜噜久久| 亚洲国产一区二区在线| 日本视频一区二区在线观看| 激情深爱综合网| 老司机性视频| av在线播放av| 一二三在线视频社区| 欧美第一页浮力影院| 国风产精品一区二区| 欧美一区二三区| 日韩欧美久久久| 少妇高潮久久77777| 欧美激情视频在线观看| 热99精品只有里视频精品| 久热国产精品视频一区二区三区| 热久久最新地址| 日本aⅴ写真网站免费| 嫩草懂你的影院| 最新国产在线拍揄自揄视频| 欧美久久天堂| 午夜免费欧美电影| 亚洲黄色av| 国产精品综合久久| 色综合久久久久综合体桃花网| 91.麻豆视频| 亚洲人在线视频| 天天人人精品| 久久久国产欧美| 免费av高清| 视频免费一区| 欧美日韩一区二区三区不卡视频| 免费成人av| 亚洲一区观看| 日韩三级视频中文字幕| 国产一区二区丝袜| 每日在线观看av| 免费的很黄很污的视频网站| 亚洲高清黄色|