精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

MySQL索引背后的數(shù)據(jù)結(jié)構(gòu)及算法之基礎(chǔ)篇

數(shù)據(jù)庫 MySQL 算法
這一章從理論角度討論了與索引相關(guān)的數(shù)據(jù)結(jié)構(gòu)與算法問題,下一章將討論B+Tree是如何具體實(shí)現(xiàn)為MySQL中索引,同時將結(jié)合MyISAM和InnDB存儲引擎介紹非聚集索引和聚集索引兩種不同的索引實(shí)現(xiàn)形式。

索引的本質(zhì)

MySQL官方對索引的定義為:索引(Index)是幫助MySQL高效獲取數(shù)據(jù)的數(shù)據(jù)結(jié)構(gòu)。提取句子主干,就可以得到索引的本質(zhì):索引是數(shù)據(jù)結(jié)構(gòu)。

我們知道,數(shù)據(jù)庫查詢是數(shù)據(jù)庫的最主要功能之一,例如下面的SQL語句:

SELECT * FROM my_table WHERE col2 = '77'

可以從表“my_table”中獲得“col2”為“77”的數(shù)據(jù)記錄。

我們都希望查詢數(shù)據(jù)的速度能盡可能的快,因此數(shù)據(jù)庫系統(tǒng)的設(shè)計者會從查詢算法的角度進(jìn)行優(yōu)化。最基本的查詢算法當(dāng)然是順序查找(linear search),遍歷“my_table”然后逐行匹配“col2”的值是否是“77”,這種復(fù)雜度為O(n)的算法在數(shù)據(jù)量很大時顯然是糟糕的,好在計算機(jī)科學(xué)的發(fā)展提供了很多更優(yōu)秀的查找算法,例如二分查找(binary search)、二叉樹查找(binary tree search)等。如果稍微分析一下會發(fā)現(xiàn),每種查找算法都只能應(yīng)用于特定的數(shù)據(jù)結(jié)構(gòu)之上,例如二分查找要求被檢索數(shù)據(jù)有序,而二叉樹查找只能應(yīng)用于二叉查找樹上,但是數(shù)據(jù)本身的組織結(jié)構(gòu)不可能完全滿足各種數(shù)據(jù)結(jié)構(gòu)(例如,理論上不可能同時將兩列都按順序進(jìn)行組織),所以,在數(shù)據(jù)之外,數(shù)據(jù)庫系統(tǒng)還維護(hù)著滿足特定查找算法的數(shù)據(jù)結(jié)構(gòu),這些數(shù)據(jù)結(jié)構(gòu)以某種方式引用(指向)數(shù)據(jù),這樣就可以在這些數(shù)據(jù)結(jié)構(gòu)上實(shí)現(xiàn)高級查找算法。這種數(shù)據(jù)結(jié)構(gòu),就是索引。

看一個例子:

圖1

圖1展示了一種可能的索引方式。左邊是數(shù)據(jù)表,一共有兩列七條記錄,最左邊的是數(shù)據(jù)記錄的物理地址(注意邏輯上相鄰的記錄在磁盤上也并不是一定物理相鄰的)。為了加快Col2的查找,可以維護(hù)一個右邊所示的二叉查找樹,每個節(jié)點(diǎn)分別包含索引鍵值和一個指向?qū)?yīng)數(shù)據(jù)記錄物理地址的指針,這樣就可以運(yùn)用二叉查找在O(log2n)的復(fù)雜度內(nèi)獲取到相應(yīng)數(shù)據(jù)。

雖然這是一個貨真價實(shí)的索引,但是實(shí)際的數(shù)據(jù)庫系統(tǒng)幾乎沒有使用二叉查找樹或其進(jìn)化品種紅黑樹(red-black tree)實(shí)現(xiàn)的,原因會在下文介紹。

B-Tree和B+Tree

目前大部分?jǐn)?shù)據(jù)庫系統(tǒng)及文件系統(tǒng)都采用B-Tree或其變種B+Tree作為索引結(jié)構(gòu),在本文的下一節(jié)會結(jié)合存儲器原理及計算機(jī)存取原理討論為什么B-Tree和B+Tree在被如此廣泛用于索引,這一節(jié)先單純從數(shù)據(jù)結(jié)構(gòu)角度描述它們。

B-Tree

為了描述B-Tree,首先定義一條數(shù)據(jù)記錄為一個二元組[key, data],key為記錄的鍵值,對于不同數(shù)據(jù)記錄,key是互不相同的;data為數(shù)據(jù)記錄除key外的數(shù)據(jù)。那么B-Tree是滿足下列條件的數(shù)據(jù)結(jié)構(gòu):

d為大于1的一個正整數(shù),稱為B-Tree的度。

h為一個正整數(shù),稱為B-Tree的高度。

每個非葉子節(jié)點(diǎn)由n-1個key和n個指針組成,其中d<=n<=2d。

每個葉子節(jié)點(diǎn)最少包含一個key和兩個指針,最多包含2d-1個key和2d個指針,葉節(jié)點(diǎn)的指針均為null 。

所有葉節(jié)點(diǎn)具有相同的深度,等于樹高h(yuǎn)。

key和指針互相間隔,節(jié)點(diǎn)兩端是指針。

一個節(jié)點(diǎn)中的key從左到右非遞減排列。

所有節(jié)點(diǎn)組成樹結(jié)構(gòu)。

每個指針要么為null,要么指向另外一個節(jié)點(diǎn)。

如果某個指針在節(jié)點(diǎn)node最左邊且不為null,則其指向節(jié)點(diǎn)的所有key小于v(key1),其中v(key1)為node的***個key的值。

如果某個指針在節(jié)點(diǎn)node最右邊且不為null,則其指向節(jié)點(diǎn)的所有key大于v(keym),其中v(keym)為node的***一個key的值。

如果某個指針在節(jié)點(diǎn)node的左右相鄰key分別是keyi和keyi+1且不為null,則其指向節(jié)點(diǎn)的所有key小于v(keyi+1)且大于v(keyi)。

圖2是一個d=2的B-Tree示意圖。

圖2

由于B-Tree的特性,在B-Tree中按key檢索數(shù)據(jù)的算法非常直觀:首先從根節(jié)點(diǎn)進(jìn)行二分查找,如果找到則返回對應(yīng)節(jié)點(diǎn)的data,否則對相應(yīng)區(qū)間的指針指向的節(jié)點(diǎn)遞歸進(jìn)行查找,直到找到節(jié)點(diǎn)或找到null指針,前者查找成功,后者查找失敗。B-Tree上查找算法的偽代碼如下:

  1. BTree_Search(node, key
  2. if(node == nullreturn null
  3. foreach(node.key
  4. if(node.key[i] == keyreturn node.data[i]; 
  5. if(node.key[i] > keyreturn BTree_Search(point[i]->node); 
  6. return BTree_Search(point[i+1]->node); 
  7. data = BTree_Search(root, my_key); 

關(guān)于B-Tree有一系列有趣的性質(zhì),例如一個度為d的B-Tree,設(shè)其索引N個key,則其樹高h(yuǎn)的上限為logd((N+1)/2),檢索一個key,其查找節(jié)點(diǎn)個數(shù)的漸進(jìn)復(fù)雜度為O(logdN)。從這點(diǎn)可以看出,B-Tree是一個非常有效率的索引數(shù)據(jù)結(jié)構(gòu)。

另外,由于插入刪除新的數(shù)據(jù)記錄會破壞B-Tree的性質(zhì),因此在插入刪除時,需要對樹進(jìn)行一個分裂、合并、轉(zhuǎn)移等操作以保持B-Tree性質(zhì),本文不打算完整討論B-Tree這些內(nèi)容,因?yàn)橐呀?jīng)有許多資料詳細(xì)說明了B-Tree的數(shù)學(xué)性質(zhì)及插入刪除算法,有興趣的朋友可以在本文末的參考文獻(xiàn)一欄找到相應(yīng)的資料進(jìn)行閱讀。

B+Tree

B-Tree有許多變種,其中最常見的是B+Tree,例如MySQL就普遍使用B+Tree實(shí)現(xiàn)其索引結(jié)構(gòu)。

與B-Tree相比,B+Tree有以下不同點(diǎn):

每個節(jié)點(diǎn)的指針上限為2d而不是2d+1。

內(nèi)節(jié)點(diǎn)不存儲data,只存儲key;葉子節(jié)點(diǎn)不存儲指針。

圖3是一個簡單的B+Tree示意。

圖3

由于并不是所有節(jié)點(diǎn)都具有相同的域,因此B+Tree中葉節(jié)點(diǎn)和內(nèi)節(jié)點(diǎn)一般大小不同。這點(diǎn)與B-Tree不同,雖然B-Tree中不同節(jié)點(diǎn)存放的key和指針可能數(shù)量不一致,但是每個節(jié)點(diǎn)的域和上限是一致的,所以在實(shí)現(xiàn)中B-Tree往往對每個節(jié)點(diǎn)申請同等大小的空間。

一般來說,B+Tree比B-Tree更適合實(shí)現(xiàn)外存儲索引結(jié)構(gòu),具體原因與外存儲器原理及計算機(jī)存取原理有關(guān),將在下面討論。

帶有順序訪問指針的B+Tree

一般在數(shù)據(jù)庫系統(tǒng)或文件系統(tǒng)中使用的B+Tree結(jié)構(gòu)都在經(jīng)典B+Tree的基礎(chǔ)上進(jìn)行了優(yōu)化,增加了順序訪問指針。

圖4

如圖4所示,在B+Tree的每個葉子節(jié)點(diǎn)增加一個指向相鄰葉子節(jié)點(diǎn)的指針,就形成了帶有順序訪問指針的B+Tree。做這個優(yōu)化的目的是為了提高區(qū)間訪問的性能,例如圖4中如果要查詢key為從18到49的所有數(shù)據(jù)記錄,當(dāng)找到18后,只需順著節(jié)點(diǎn)和指針順序遍歷就可以一次性訪問到所有數(shù)據(jù)節(jié)點(diǎn),極大提到了區(qū)間查詢效率。

這一節(jié)對B-Tree和B+Tree進(jìn)行了一個簡單的介紹,下一節(jié)結(jié)合存儲器存取原理介紹為什么目前B+Tree是數(shù)據(jù)庫系統(tǒng)實(shí)現(xiàn)索引的***數(shù)據(jù)結(jié)構(gòu)。

#p#

為什么使用B-Tree(B+Tree)

上文說過,紅黑樹等數(shù)據(jù)結(jié)構(gòu)也可以用來實(shí)現(xiàn)索引,但是文件系統(tǒng)及數(shù)據(jù)庫系統(tǒng)普遍采用B-/+Tree作為索引結(jié)構(gòu),這一節(jié)將結(jié)合計算機(jī)組成原理相關(guān)知識討論B-/+Tree作為索引的理論基礎(chǔ)。

一般來說,索引本身也很大,不可能全部存儲在內(nèi)存中,因此索引往往以索引文件的形式存儲的磁盤上。這樣的話,索引查找過程中就要產(chǎn)生磁盤I/O消耗,相對于內(nèi)存存取,I/O存取的消耗要高幾個數(shù)量級,所以評價一個數(shù)據(jù)結(jié)構(gòu)作為索引的優(yōu)劣最重要的指標(biāo)就是在查找過程中磁盤I/O操作次數(shù)的漸進(jìn)復(fù)雜度。換句話說,索引的結(jié)構(gòu)組織要盡量減少查找過程中磁盤I/O的存取次數(shù)。下面先介紹內(nèi)存和磁盤存取原理,然后再結(jié)合這些原理分析B-/+Tree作為索引的效率。

主存存取原理

目前計算機(jī)使用的主存基本都是隨機(jī)讀寫存儲器(RAM),現(xiàn)代RAM的結(jié)構(gòu)和存取原理比較復(fù)雜,這里本文拋卻具體差別,抽象出一個十分簡單的存取模型來說明RAM的工作原理。

圖5

從抽象角度看,主存是一系列的存儲單元組成的矩陣,每個存儲單元存儲固定大小的數(shù)據(jù)。每個存儲單元有唯一的地址,現(xiàn)代主存的編址規(guī)則比較復(fù)雜,這里將其簡化成一個二維地址:通過一個行地址和一個列地址可以唯一定位到一個存儲單元。圖5展示了一個4 x 4的主存模型。

主存的存取過程如下:

當(dāng)系統(tǒng)需要讀取主存時,則將地址信號放到地址總線上傳給主存,主存讀到地址信號后,解析信號并定位到指定存儲單元,然后將此存儲單元數(shù)據(jù)放到數(shù)據(jù)總線上,供其它部件讀取。

寫主存的過程類似,系統(tǒng)將要寫入單元地址和數(shù)據(jù)分別放在地址總線和數(shù)據(jù)總線上,主存讀取兩個總線的內(nèi)容,做相應(yīng)的寫操作。

這里可以看出,主存存取的時間僅與存取次數(shù)呈線性關(guān)系,因?yàn)椴淮嬖跈C(jī)械操作,兩次存取的數(shù)據(jù)的“距離”不會對時間有任何影響,例如,先取A0再取A1和先取A0再取D3的時間消耗是一樣的。

磁盤存取原理

上文說過,索引一般以文件形式存儲在磁盤上,索引檢索需要磁盤I/O操作。與主存不同,磁盤I/O存在機(jī)械運(yùn)動耗費(fèi),因此磁盤I/O的時間消耗是巨大的。

圖6是磁盤的整體結(jié)構(gòu)示意圖。

圖6

一個磁盤由大小相同且同軸的圓形盤片組成,磁盤可以轉(zhuǎn)動(各個磁盤必須同步轉(zhuǎn)動)。在磁盤的一側(cè)有磁頭支架,磁頭支架固定了一組磁頭,每個磁頭負(fù)責(zé)存取一個磁盤的內(nèi)容。磁頭不能轉(zhuǎn)動,但是可以沿磁盤半徑方向運(yùn)動(實(shí)際是斜切向運(yùn)動),每個磁頭同一時刻也必須是同軸的,即從正上方向下看,所有磁頭任何時候都是重疊的(不過目前已經(jīng)有多磁頭獨(dú)立技術(shù),可不受此限制)。

圖7是磁盤結(jié)構(gòu)的示意圖。

圖7

盤片被劃分成一系列同心環(huán),圓心是盤片中心,每個同心環(huán)叫做一個磁道,所有半徑相同的磁道組成一個柱面。磁道被沿半徑線劃分成一個個小的段,每個段叫做一個扇區(qū),每個扇區(qū)是磁盤的最小存儲單元。為了簡單起見,我們下面假設(shè)磁盤只有一個盤片和一個磁頭。

當(dāng)需要從磁盤讀取數(shù)據(jù)時,系統(tǒng)會將數(shù)據(jù)邏輯地址傳給磁盤,磁盤的控制電路按照尋址邏輯將邏輯地址翻譯成物理地址,即確定要讀的數(shù)據(jù)在哪個磁道,哪個扇區(qū)。為了讀取這個扇區(qū)的數(shù)據(jù),需要將磁頭放到這個扇區(qū)上方,為了實(shí)現(xiàn)這一點(diǎn),磁頭需要移動對準(zhǔn)相應(yīng)磁道,這個過程叫做尋道,所耗費(fèi)時間叫做尋道時間,然后磁盤旋轉(zhuǎn)將目標(biāo)扇區(qū)旋轉(zhuǎn)到磁頭下,這個過程耗費(fèi)的時間叫做旋轉(zhuǎn)時間。

局部性原理與磁盤預(yù)讀

由于存儲介質(zhì)的特性,磁盤本身存取就比主存慢很多,再加上機(jī)械運(yùn)動耗費(fèi),磁盤的存取速度往往是主存的幾百分分之一,因此為了提高效率,要盡量減少磁盤I/O。為了達(dá)到這個目的,磁盤往往不是嚴(yán)格按需讀取,而是每次都會預(yù)讀,即使只需要一個字節(jié),磁盤也會從這個位置開始,順序向后讀取一定長度的數(shù)據(jù)放入內(nèi)存。這樣做的理論依據(jù)是計算機(jī)科學(xué)中著名的局部性原理:

當(dāng)一個數(shù)據(jù)被用到時,其附近的數(shù)據(jù)也通常會馬上被使用。

程序運(yùn)行期間所需要的數(shù)據(jù)通常比較集中。

由于磁盤順序讀取的效率很高(不需要尋道時間,只需很少的旋轉(zhuǎn)時間),因此對于具有局部性的程序來說,預(yù)讀可以提高I/O效率。

預(yù)讀的長度一般為頁(page)的整倍數(shù)。頁是計算機(jī)管理存儲器的邏輯塊,硬件及操作系統(tǒng)往往將主存和磁盤存儲區(qū)分割為連續(xù)的大小相等的塊,每個存儲塊稱為一頁(在許多操作系統(tǒng)中,頁得大小通常為4k),主存和磁盤以頁為單位交換數(shù)據(jù)。當(dāng)程序要讀取的數(shù)據(jù)不在主存中時,會觸發(fā)一個缺頁異常,此時系統(tǒng)會向磁盤發(fā)出讀盤信號,磁盤會找到數(shù)據(jù)的起始位置并向后連續(xù)讀取一頁或幾頁載入內(nèi)存中,然后異常返回,程序繼續(xù)運(yùn)行。

B-/+Tree索引的性能分析

到這里終于可以分析B-/+Tree索引的性能了。

上文說過一般使用磁盤I/O次數(shù)評價索引結(jié)構(gòu)的優(yōu)劣。先從B-Tree分析,根據(jù)B-Tree的定義,可知檢索一次最多需要訪問h個節(jié)點(diǎn)。數(shù)據(jù)庫系統(tǒng)的設(shè)計者巧妙利用了磁盤預(yù)讀原理,將一個節(jié)點(diǎn)的大小設(shè)為等于一個頁,這樣每個節(jié)點(diǎn)只需要一次I/O就可以完全載入。為了達(dá)到這個目的,在實(shí)際實(shí)現(xiàn)B- Tree還需要使用如下技巧:

每次新建節(jié)點(diǎn)時,直接申請一個頁的空間,這樣就保證一個節(jié)點(diǎn)物理上也存儲在一個頁里,加之計算機(jī)存儲分配都是按頁對齊的,就實(shí)現(xiàn)了一個node只需一次I/O。

B-Tree中一次檢索最多需要h-1次I/O(根節(jié)點(diǎn)常駐內(nèi)存),漸進(jìn)復(fù)雜度為O(h)=O(logdN)。一般實(shí)際應(yīng)用中,出度d是非常大的數(shù)字,通常超過100,因此h非常小(通常不超過3)。

綜上所述,用B-Tree作為索引結(jié)構(gòu)效率是非常高的。

而紅黑樹這種結(jié)構(gòu),h明顯要深的多。由于邏輯上很近的節(jié)點(diǎn)(父子)物理上可能很遠(yuǎn),無法利用局部性,所以紅黑樹的I/O漸進(jìn)復(fù)雜度也為O(h),效率明顯比B-Tree差很多。

上文還說過,B+Tree更適合外存索引,原因和內(nèi)節(jié)點(diǎn)出度d有關(guān)。從上面分析可以看到,d越大索引的性能越好,而出度的上限取決于節(jié)點(diǎn)內(nèi)key和data的大小:

dmax = floor(pagesize / (keysize + datasize + pointsize)) (pagesize – dmax >= pointsize)

dmax = floor(pagesize / (keysize + datasize + pointsize)) - 1 (pagesize – dmax < pointsize)

floor表示向下取整。由于B+Tree內(nèi)節(jié)點(diǎn)去掉了data域,因此可以擁有更大的出度,擁有更好的性能。

這一章從理論角度討論了與索引相關(guān)的數(shù)據(jù)結(jié)構(gòu)與算法問題,下一章將討論B+Tree是如何具體實(shí)現(xiàn)為MySQL中索引,同時將結(jié)合MyISAM和InnDB存儲引擎介紹非聚集索引和聚集索引兩種不同的索引實(shí)現(xiàn)形式。

原文鏈接:http://www.cnblogs.com/leoo2sk/archive/2011/07/10/mysql-index.html

【編輯推薦】

  1. MySQL中創(chuàng)建及優(yōu)化索引組織結(jié)構(gòu)的思路
  2. 微博 請問你是怎么優(yōu)化數(shù)據(jù)庫的?
  3. MySQL技巧:結(jié)合相關(guān)參數(shù) 做好Limit優(yōu)化
  4. MySQL數(shù)據(jù)庫的優(yōu)化(下)MySQL數(shù)據(jù)庫的高可用架構(gòu)方案
  5. MySQL數(shù)據(jù)庫的優(yōu)化(上)單機(jī)MySQL數(shù)據(jù)庫的優(yōu)化
責(zé)任編輯:艾婧 來源: EricZhang's Technology Blog
相關(guān)推薦

2011-07-11 15:03:36

MySQL索引數(shù)據(jù)結(jié)構(gòu)

2011-07-11 16:05:42

MySQL索引

2023-10-30 08:31:42

數(shù)據(jù)結(jié)構(gòu)算法

2017-05-11 11:59:12

MySQL數(shù)據(jù)結(jié)構(gòu)算法原理

2011-07-11 15:28:19

MySQL索引優(yōu)化

2021-07-16 04:57:45

Go算法結(jié)構(gòu)

2023-04-12 16:45:07

MySQL索引數(shù)據(jù)結(jié)構(gòu)

2021-10-12 07:58:10

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

2021-12-10 11:27:59

數(shù)據(jù)結(jié)構(gòu)算法單調(diào)遞增的數(shù)字

2021-05-12 14:09:35

鏈表數(shù)據(jù)結(jié)構(gòu)線性結(jié)構(gòu)

2023-12-28 10:54:58

MySQL記錄存儲

2022-09-26 07:56:53

AVL算法二叉樹

2022-09-21 07:57:33

二叉搜索樹排序二叉樹

2020-10-30 09:56:59

Trie樹之美

2020-12-31 05:31:01

數(shù)據(jù)結(jié)構(gòu)算法

2020-10-20 08:14:08

算法與數(shù)據(jù)結(jié)構(gòu)

2020-10-12 11:48:31

算法與數(shù)據(jù)結(jié)構(gòu)

2022-01-18 19:13:52

背包問題數(shù)據(jù)結(jié)構(gòu)算法

2020-10-21 14:57:04

數(shù)據(jù)結(jié)構(gòu)算法圖形

2023-03-08 08:03:09

數(shù)據(jù)結(jié)構(gòu)算法歸并排序
點(diǎn)贊
收藏

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

在线看日韩欧美| 在线看日韩精品电影| 国产高清在线一区二区| 国产成人无码精品久久久久| 欧美尿孔扩张虐视频| 色婷婷亚洲综合| 91手机视频在线| 婷婷丁香花五月天| 麻豆精品久久精品色综合| 欧美久久精品一级黑人c片| 黄色免费视频网站| 日本黄色一区| 亚洲一二三四久久| 亚洲日本精品国产第一区| 精品人妻少妇AV无码专区| 欧美在线综合| 欧美裸体xxxx极品少妇| 91国模少妇一区二区三区| 日本在线成人| 欧美日韩一区三区| 日韩欧美视频网站| 成人免费网站在线观看视频| 久久久午夜精品理论片中文字幕| 91欧美精品成人综合在线观看| 日韩av在线播| 亚洲欧美一区在线| 中文字幕日韩欧美在线视频| 中文字幕乱码一区| 欧美成人一级| 欧美日韩一区二区三区免费看| 日韩av高清在线看片| 国产激情视频在线| 国产精品私人影院| 欧美久久电影| 天天操天天干天天爱| 久99久精品视频免费观看| 国产成人极品视频| 可以免费看的av毛片| 狠狠爱成人网| 欧美精品在线免费观看| 久久人妻无码aⅴ毛片a片app| 国产亚洲一区| 国产香蕉精品视频一区二区三区| 国产 中文 字幕 日韩 在线| 成人动漫视频| 亚洲白虎美女被爆操| 日本黄色www| 日韩精品亚洲专区在线观看| 在线电影国产精品| 一级黄色高清视频| 激情久久免费视频| 欧美一二三四在线| 成人做爰69片免费| 一本一道久久a久久| 日韩一区二区三区精品视频| 不用播放器的免费av| 欧美大片网站| 69av一区二区三区| 丰满少妇一区二区三区专区| 国产69精品久久| 欧美色图免费看| 91插插插插插插插插| 亚洲高清黄色| 欧美日韩情趣电影| 男生操女生视频在线观看| 亚洲一区二区三区四区| 91久久国产最好的精华液| 久久久久人妻精品一区三寸| 三级中文字幕在线观看| 天天av天天翘天天综合网| 国产精品久久久久9999爆乳| 久久不射影院| 亚洲福利视频三区| 日本a级片在线观看| 99热国产在线| 一区二区国产视频| 美脚丝袜脚交一区二区| mm视频在线视频| 亚洲成av人在线观看| 69sex久久精品国产麻豆| 欧美黑人xx片| 香港成人在线视频| 国产免费一区二区三区视频| 黄色综合网址| 欧美性三三影院| 色播五月激情五月| 国产精品一区三区在线观看| 欧美图片一区二区三区| 少妇一级淫免费播放| 国产精品一区免费在线| 精品少妇一区二区三区| 亚洲天堂资源在线| 国产一区日韩| 久久九九热免费视频| 日韩欧美123区| 亚洲一区区二区| 国产精品福利无圣光在线一区| 国产天堂第一区| 黄色小说综合网站| 国产91精品入口17c| 手机在线精品视频| 国产欧美久久久精品影院| 亚洲欧洲日夜超级视频| 午夜av在线播放| 欧美性猛交xxxx乱大交3| www.日日操| 人人精品久久| 精品视频在线播放| 欧美手机在线观看| 国产欧美一级| 国产欧美在线视频| 六月丁香色婷婷| 亚洲国产高清不卡| 992tv快乐视频| 超碰一区二区| 91精品国产色综合久久不卡电影| 日韩欧美中文在线视频| 国产一区网站| 国产+人+亚洲| 中文字幕日韩经典| 国产999精品久久| 色噜噜狠狠一区二区三区| av电影免费在线观看| 色综合久久九月婷婷色综合| 红桃视频 国产| 亚洲福利天堂| 欧美精品一本久久男人的天堂| 精人妻无码一区二区三区| 高清国产午夜精品久久久久久| 欧美日韩综合另类| 欧洲成人综合网| 欧美日韩一区二区电影| 催眠调教后宫乱淫校园| 天天做天天爱天天综合网| 欧美亚洲日本网站| 999久久久久| 亚洲国产高清aⅴ视频| 日本五级黄色片| 久久国产精品美女| 自拍偷拍亚洲一区| 亚洲黄色激情视频| 大白屁股一区二区视频| 中文字幕日韩一区二区三区| 国产日韩另类视频一区| 亚洲电影天堂av| 福利所第一导航| 极品少妇xxxx精品少妇偷拍| 青青草国产精品| 天堂√8在线中文| 亚洲第一区中文99精品| 国产精品白嫩白嫩大学美女| 久久成人久久鬼色| 特级西西444www大精品视频| 中国色在线日|韩| 亚洲国产精彩中文乱码av| 九九免费精品视频| 精品一区二区三区免费| 在线免费观看成人| 91成人app| 日韩一中文字幕| 在线视频免费观看一区| 亚洲国产精品激情在线观看| 久久久99精品视频| 日韩一级淫片| 欧美大片大片在线播放| 国产ts变态重口人妖hd| 亚洲男人的天堂网| 91丝袜超薄交口足| 亚洲夜间福利| 国内精品久久国产| 182在线播放| 日韩av在线一区| 毛片基地在线观看| 国产亚洲精品aa午夜观看| 日本激情视频在线| 999久久久91| 亚洲a成v人在线观看| 国产剧情在线| 精品国产一区二区三区av性色| 欧美精品入口蜜桃| 国产乱人伦偷精品视频不卡| 亚洲精品蜜桃久久久久久| 久久综合五月婷婷| 日韩av不卡电影| 91视频在线观看| 91精品在线一区二区| 妺妺窝人体色www在线下载| 成人午夜视频福利| 国产主播自拍av| 成人在线一区| 亚洲最大福利视频| 狠狠操一区二区三区| 亚洲无av在线中文字幕| 亚洲中文字幕在线一区| 亚洲色图欧洲色图婷婷| 特级特黄刘亦菲aaa级| 欧美亚洲一级| 法国空姐在线观看免费| 成人资源在线| 国产精品激情av电影在线观看| 巨大荫蒂视频欧美大片| 亚洲成人精品视频| 久操视频在线免费观看| 综合久久综合久久| 一区二区免费在线观看视频| 99亚洲视频| 亚洲综合av一区| 日韩av资源网| 91久久精品美女高潮| av在线播放资源| 一区二区在线视频播放| 99久久久久成人国产免费| 天天爽夜夜爽夜夜爽精品视频| youjizz亚洲女人| 国产不卡视频在线播放| 亚洲国产高清av| 亚洲人成久久| 五月天男人天堂| 亚洲黄色录像| 97人人干人人| 成人午夜一级| 久久久在线视频| 国产资源在线看| 日韩av资源在线播放| 国产伦精品一区二区三区视频痴汉| 亚洲亚洲人成综合网络| 潮喷失禁大喷水aⅴ无码| 99视频一区二区| 欧美一级免费在线| 蜜臀av一区二区| 91国视频在线| 国产精品扒开腿做爽爽爽软件| 日韩欧美一区二区视频在线播放| 亚洲精品在线a| 国产在线精品成人一区二区三区| 亚洲优女在线| 久久久久久有精品国产| 成人无遮挡免费网站视频在线观看| 中文字幕欧美日韩va免费视频| 亚洲欧洲综合在线| 欧美成人精品高清在线播放| 91精品在线视频观看| 一本色道亚洲精品aⅴ| 国产精品a成v人在线播放| 18成人在线视频| jizz日本在线播放| 久久亚洲一区二区三区明星换脸| 美女伦理水蜜桃4| 国产精品一区二区久久精品爱涩 | 一级做a爱片久久毛片| 欧美日韩综合视频| 日本熟妇毛耸耸xxxxxx| 一区二区三区欧美视频| 三上悠亚作品在线观看| 欧美成人黄色| 亚洲天堂久久av| 日本一二三区在线视频| 亚洲韩国青草视频| 国产福利免费视频| 日韩欧美卡一卡二| www久久久久久| 欧美一级久久久| 精品久久国产视频| 日韩一区二区免费高清| 精品国产999久久久免费| 日韩欧美精品三级| 亚洲国产精彩视频| 欧美精品一区二区蜜臀亚洲| 神宫寺奈绪一区二区三区| 亚洲电影免费观看高清完整版在线观看| 亚洲第九十九页| 亚洲精品国产精品国产自| 欧美男男激情freegay| 亚洲欧美在线免费观看| 精品无人乱码| 中文字幕在线亚洲| 高h视频在线观看| 欧美高跟鞋交xxxxhd| 国产乱色在线观看| 91精品国产免费久久久久久| 涩涩视频网站在线观看| 日韩av免费一区| 97精品国产99久久久久久免费| 国产精品视频1区| 豆花视频一区| 黄色99视频| 精品国产一区一区二区三亚瑟| 日韩少妇中文字幕| 91精品综合久久久久久久久久久 | 天天操天天爱天天爽| 精品一区二区在线播放| 中文字幕av一区二区三区人妻少妇| 国产激情偷乱视频一区二区三区| 韩国三级在线看| www激情久久| 成人黄色短视频| 亚洲午夜精品在线| 最近中文在线观看| 日韩欧美一级精品久久| 天堂在线免费av| 色99之美女主播在线视频| 日韩专区av| 国产成人精品视频| 久久69成人| 久久久久久欧美精品色一二三四| 日本道不卡免费一区| 免费人成在线观看视频播放| 乱人伦精品视频在线观看| 亚洲午夜激情影院| 97久久超碰国产精品电影| 欧美成人国产精品高潮| 色国产精品一区在线观看| 国产欧美日韩综合精品一区二区三区| 亚洲白虎美女被爆操| 日本中文在线观看| 色综合老司机第九色激情| 日韩精品一区二区三区av| 福利精品视频| 欧美mv日韩| 黄色一级片播放| 狠狠久久亚洲欧美| 完美搭档在线观看| 一区二区三区国产豹纹内裤在线| 日本中文字幕第一页| 欧美一级国产精品| av网页在线| 51久久精品夜色国产麻豆| 国外成人福利视频| 欧美一区二区高清在线观看| 亚洲破处大片| 日韩av一二三四| 成人白浆超碰人人人人| 欧美三级黄色大片| 在线观看日产精品| 日韩av高清在线| 久久久久久香蕉网| 日本在线成人| 午夜啪啪福利视频| 蜜桃一区二区三区在线观看| 亚洲视频天天射| 亚洲综合免费观看高清在线观看| 中文字幕日产av| 一区二区在线视频播放| 久久人体大尺度| 国产精品视频福利| 亚洲成人tv| 污免费在线观看| 亚洲天堂福利av| 中文字幕 视频一区| 精品香蕉一区二区三区| 大桥未久在线视频| 精品国产乱码一区二区三区四区 | www.av片| 国产成人午夜精品影院观看视频 | 一区二区视频在线看| 国产精品视频在线观看免费| 中文字幕av日韩| 国产精品第一| 亚洲欧洲日韩精品| 久久91精品久久久久久秒播| 激情五月激情综合| 在线电影一区二区三区| 成人在线观看亚洲| 成人性生交大片免费看视频直播 | 成人久久18免费网站麻豆| 久久久久久久久毛片| 日韩欧美一区二区不卡| 性开放的欧美大片| 亚洲综合自拍一区| 综合精品一区| 亚洲国产精品狼友在线观看| 亚洲国产成人av| 香蕉视频黄色片| 国产精品三级网站| 亚洲天堂免费| 激情综合激情五月| 精品久久久久久久久久国产| 婷婷色在线视频| 久久久久久久久亚洲| 嫩草影视亚洲| 午夜精品在线免费观看| 国产精品国产三级国产aⅴ无密码| 亚洲天堂网视频| 久久夜色精品国产欧美乱| 日韩成人在线观看视频| 国产av人人夜夜澡人人爽麻豆| 91性感美女视频| 在线免费看av的网站| 欧美激情va永久在线播放| 女人丝袜激情亚洲| 国产一伦一伦一伦| 一区二区高清视频在线观看| 色综合免费视频| 国产精品日韩欧美综合| 欧美日韩亚洲一区| 国产男男chinese网站| 欧美日本不卡视频| av电影在线免费| 天堂av一区二区| 99久久99久久综合|