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

再有人問你為什么MySQL用B+樹做索引,就把這篇文章發(fā)給她

數(shù)據(jù)庫 MySQL
索引這個詞,相信大多數(shù)人已經(jīng)相當(dāng)熟悉了,很多人都知道MySQL的索引主要以B+樹為主,但是要問到為什么用B+樹,恐怕很少有人能把前因后果講述的很完整。本文就來從頭到尾介紹下數(shù)據(jù)庫的索引。

[[281247]]

索引這個詞,相信大多數(shù)人已經(jīng)相當(dāng)熟悉了,很多人都知道MySQL的索引主要以B+樹為主,但是要問到為什么用B+樹,恐怕很少有人能把前因后果講述的很完整。本文就來從頭到尾介紹下數(shù)據(jù)庫的索引。

索引是一種數(shù)據(jù)結(jié)構(gòu),用于幫助我們在大量數(shù)據(jù)中快速定位到我們想要查找的數(shù)據(jù)。 索引最形象的比喻就是圖書的目錄了。注意這里的大量,數(shù)據(jù)量大了索引才顯得有意義,如果我想要在[1,2,3,4]中找到4這個數(shù)據(jù),直接對全數(shù)據(jù)檢索也很快,沒有必要費(fèi)力氣建索引再去查找。索引在mysql數(shù)據(jù)庫中分三類:

B+樹索引、Hash索引、全文索引

我們今天要介紹的是工作開發(fā)中最常接觸到innodb存儲引擎中的的B+樹索引。

要介紹B+樹索引,就不得不提二叉查找樹,平衡二叉樹和B樹這三種數(shù)據(jù)結(jié)構(gòu)。B+樹就是從他們仨演化來的。

二叉查找樹

首先,讓我們先看一張圖。

從圖中可以看到,我們?yōu)閡ser表(用戶信息表)建立了一個二叉查找樹的索引。圖中的圓為二叉查找樹的節(jié)點(diǎn),節(jié)點(diǎn)中存儲了鍵(key)和數(shù)據(jù)(data)。

鍵對應(yīng)user表中的id,數(shù)據(jù)對應(yīng)user表中的行數(shù)據(jù)。二叉查找樹的特點(diǎn)就是任何節(jié)點(diǎn)的左子節(jié)點(diǎn)的鍵值都小于當(dāng)前節(jié)點(diǎn)的鍵值,右子節(jié)點(diǎn)的鍵值都大于當(dāng)前節(jié)點(diǎn)的鍵值。 頂端的節(jié)點(diǎn)我們稱為根節(jié)點(diǎn),沒有子節(jié)點(diǎn)的節(jié)點(diǎn)我們稱之為葉節(jié)點(diǎn)。

如果我們需要查找id=12的用戶信息,利用我們創(chuàng)建的二叉查找樹索引,查找流程如下:

  • 1. 將根節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn),把12與當(dāng)前節(jié)點(diǎn)的鍵值10比較,12大于10,接下來我們把當(dāng)前節(jié)點(diǎn)>的右子節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn)。
  • 2. 繼續(xù)把12和當(dāng)前節(jié)點(diǎn)的鍵值13比較,發(fā)現(xiàn)12小于13,把當(dāng)前節(jié)點(diǎn)的左子節(jié)點(diǎn)作為當(dāng)前節(jié)點(diǎn)。
  • 3. 把12和當(dāng)前節(jié)點(diǎn)的鍵值12對比,12等于12,滿足條件,我們從當(dāng)前節(jié)點(diǎn)中取出data,即id=1>2,name=xm。

利用二叉查找樹我們只需要3次即可找到匹配的數(shù)據(jù)。如果在表中一條條的查找的話,我們需要6次才能找到。

平衡二叉樹

上面我們講解了利用二叉查找樹可以快速的找到數(shù)據(jù)。但是,如果上面的二叉查找樹是這樣的構(gòu)造:

 

這個時候可以看到我們的二叉查找樹變成了一個鏈表。

如果我們需要查找id=17的用戶信息,我們需要查找7次,也就相當(dāng)于全表掃描了。

導(dǎo)致這個現(xiàn)象的原因其實(shí)是二叉查找樹變得不平衡了,也就是高度太高了,從而導(dǎo)致查找效率的不穩(wěn)定。

為了解決這個問題,我們需要保證二叉查找樹一直保持平衡,就需要用到平衡二叉樹了。

平衡二叉樹又稱AVL樹,在滿足二叉查找樹特性的基礎(chǔ)上,要求每個節(jié)點(diǎn)的左右子樹的高度不能超過1。

下面是平衡二叉樹和非平衡二叉樹的對比:

 

由平衡二叉樹的構(gòu)造我們可以發(fā)現(xiàn)第一張圖中的二叉樹其實(shí)就是一棵平衡二叉樹。

平衡二叉樹保證了樹的構(gòu)造是平衡的,當(dāng)我們插入或刪除數(shù)據(jù)導(dǎo)致不滿足平衡二叉樹不平衡時,平衡二叉樹會進(jìn)行調(diào)整樹上的節(jié)點(diǎn)來保持平衡。具體的調(diào)整方式這里就不介紹了。

平衡二叉樹相比于二叉查找樹來說,查找效率更穩(wěn)定,總體的查找速度也更快。

B樹

因?yàn)閮?nèi)存的易失性。一般情況下,我們都會選擇將user表中的數(shù)據(jù)和索引存儲在磁盤這種外圍設(shè)備中。

但是和內(nèi)存相比,從磁盤中讀取數(shù)據(jù)的速度會慢上百倍千倍甚至萬倍,所以,我們應(yīng)當(dāng)盡量減少從磁盤中讀取數(shù)據(jù)的次數(shù)。 另外,從磁盤中讀取數(shù)據(jù)時,都是按照磁盤塊來讀取的,并不是一條一條的讀。

如果我們能把盡量多的數(shù)據(jù)放進(jìn)磁盤塊中,那一次磁盤讀取操作就會讀取更多數(shù)據(jù),那我們查找數(shù)據(jù)的時間也會大幅度降低。

如果我們用樹這種數(shù)據(jù)結(jié)構(gòu)作為索引的數(shù)據(jù)結(jié)構(gòu),那我們每查找一次數(shù)據(jù)就需要從磁盤中讀取一個節(jié)點(diǎn),也就是我們說的一個磁盤塊,我們都知道平衡二叉樹可是每個節(jié)點(diǎn)只存儲一個鍵值和數(shù)據(jù)的。

那說明什么?

說明每個磁盤塊僅僅存儲一個鍵值和數(shù)據(jù)!

那如果我們要存儲海量的數(shù)據(jù)呢?

可以想象到二叉樹的節(jié)點(diǎn)將會非常多,高度也會及其高,我們查找數(shù)據(jù)時也會進(jìn)行很多次磁盤IO,我們查找數(shù)據(jù)的效率將會極低!

 

為了解決平衡二叉樹的這個弊端,我們應(yīng)該尋找一種單個節(jié)點(diǎn)可以存儲多個鍵值和數(shù)據(jù)的平衡樹。也就是我們接下來要說的B樹。

B樹(Balance Tree)即為平衡樹的意思,下圖即是一顆B樹。

圖中的p節(jié)點(diǎn)為指向子節(jié)點(diǎn)的指針,二叉查找樹和平衡二叉樹其實(shí)也有,因?yàn)閳D的美觀性,被省略了。- 圖中的每個節(jié)點(diǎn)稱為頁,頁就是我們上面說的磁盤塊,在mysql中數(shù)據(jù)讀取的基本單位都是頁,所以我們這里叫做頁更符合mysql中索引的底層數(shù)據(jù)結(jié)構(gòu)。

從上圖可以看出,B樹相對于平衡二叉樹,每個節(jié)點(diǎn)存儲了更多的鍵值(key)和數(shù)據(jù)(data),并且每個節(jié)點(diǎn)擁有更多的子節(jié)點(diǎn),子節(jié)點(diǎn)的個數(shù)一般稱為階,上述圖中的B樹為3階B樹,高度也會很低。 基于這個特性,B樹查找數(shù)據(jù)讀取磁盤的次數(shù)將會很少,數(shù)據(jù)的查找效率也會比平衡二叉樹高很多。

假如我們要查找id=28的用戶信息,那么我們在上圖B樹中查找的流程如下:

  • 1. 先找到根節(jié)點(diǎn)也就是頁1,判斷28在鍵值17和35之間,我們那么我們根據(jù)頁1中的指針p2找到頁3。
  • 2. 將28和頁3中的鍵值相比較,28在26和30之間,我們根據(jù)頁3中的指針p2找到頁8。
  • 3. 將28和頁8中的鍵值相比較,發(fā)現(xiàn)有匹配的鍵值28,鍵值28對應(yīng)的用戶信息為(28,bv)。

B+樹

B+樹是對B樹的進(jìn)一步優(yōu)化。讓我們先來看下B+樹的結(jié)構(gòu)圖:

 

根據(jù)上圖我們來看下B+樹和B樹有什么不同。 

1. B+樹非葉子節(jié)點(diǎn)上是不存儲數(shù)據(jù)的,僅存儲鍵值,而B樹節(jié)點(diǎn)中不僅存儲鍵值,也會存儲數(shù)據(jù)。之所以這么做是因?yàn)樵跀?shù)據(jù)庫中頁的大小是固定的,innodb中頁的默認(rèn)大小是16KB。如果不存儲數(shù)據(jù),那么就會存儲更多的鍵值,相應(yīng)的樹的階數(shù)(節(jié)點(diǎn)的子節(jié)點(diǎn)樹)就會更大,樹就會更矮更胖,如此一來我們查找數(shù)據(jù)進(jìn)行磁盤的IO次數(shù)有會再次減少,數(shù)據(jù)查詢的效率也會更快。另外,B+樹的階數(shù)是等于鍵值的數(shù)量的,如果我們的B+樹一個節(jié)點(diǎn)可以存儲1000個鍵值,那么3層B+樹可以存儲1000×1000×1000=10億個數(shù)據(jù)。一般根節(jié)點(diǎn)是常駐內(nèi)存的,所以一般我們查找10億數(shù)據(jù),只需要2次磁盤IO。

2. 因?yàn)锽+樹索引的所有數(shù)據(jù)均存儲在葉子節(jié)點(diǎn),而且數(shù)據(jù)是按照順序排列的。那么B+樹使得范圍查找,排序查找,分組查找以及去重查找變得異常簡單。而B樹因?yàn)閿?shù)據(jù)分散在各個節(jié)點(diǎn),要實(shí)現(xiàn)這一點(diǎn)是很不容易的。

有心的讀者可能還發(fā)現(xiàn)上圖B+樹中各個頁之間是通過雙向鏈表連接的,葉子節(jié)點(diǎn)中的數(shù)據(jù)是通過單向鏈表連接的。

其實(shí)上面的B樹我們也可以對各個節(jié)點(diǎn)加上鏈表。其實(shí)這些不是它們之前的區(qū)別,是因?yàn)樵趍ysql的innodb存儲引擎中,索引就是這樣存儲的。也就是說上圖中的B+樹索引就是innodb中B+樹索引真正的實(shí)現(xiàn)方式,準(zhǔn)確的說應(yīng)該是聚集索引(聚集索引和非聚集索引下面會講到)。

通過上圖可以看到,在innodb中,我們通過數(shù)據(jù)頁之間通過雙向鏈表連接以及葉子節(jié)點(diǎn)中數(shù)據(jù)之間通過單向鏈表連接的方式可以找到表中所有的數(shù)據(jù)。

MyISAM中的B+樹索引實(shí)現(xiàn)與innodb中的略有不同。在MyISAM中,B+樹索引的葉子節(jié)點(diǎn)并不存儲數(shù)據(jù),而是存儲數(shù)據(jù)的文件地址。

聚集索引 VS 非聚集索引

在上節(jié)介紹B+樹索引的時候,我們提到了圖中的索引其實(shí)是聚集索引的實(shí)現(xiàn)方式。那什么是聚集索引呢?

在MySQL中,B+樹索引按照存儲方式的不同分為聚集索引和非聚集索引。

這里我們著重介紹innodb中的聚集索引和非聚集索引。

1. 聚集索引(聚簇索引):以innodb作為存儲引擎的表,表中的數(shù)據(jù)都會有一個主鍵,即使你不創(chuàng)建主鍵,系統(tǒng)也會幫你創(chuàng)建一個隱式的主鍵。這是因?yàn)閕nnodb是把數(shù)據(jù)存放在B+樹中的,而B+樹的鍵值就是主鍵,在B+樹的葉子節(jié)點(diǎn)中,存儲了表中所有的數(shù)據(jù)。這種以主鍵作為B+樹索引的鍵值而構(gòu)建的B+樹索引,我們稱之為聚集索引。

2. 非聚集索引(非聚簇索引):以主鍵以外的列值作為鍵值構(gòu)建的B+樹索引,我們稱之為非聚集索引。非聚集索引與聚集索引的區(qū)別在于非聚集索引的葉子節(jié)點(diǎn)不存儲表中的數(shù)據(jù),而是存儲該列對應(yīng)的主鍵,想要查找數(shù)據(jù)我們還需要根據(jù)主鍵再去聚集索引中進(jìn)行查找,這個再根據(jù)聚集索引查找數(shù)據(jù)的過程,我們稱為回表。

明白了聚集索引和非聚集索引的定義,我們應(yīng)該明白這樣一句話:數(shù)據(jù)即索引,索引即數(shù)據(jù)。

利用聚集索引和非聚集索引查找數(shù)據(jù)

前面我們講解B+樹索引的時候并沒有去說怎么在B+樹中進(jìn)行數(shù)據(jù)的查找,主要就是因?yàn)檫€沒有引出聚集索引和非聚集索引的概念。下面我們通過講解如何通過聚集索引以及非聚集索引查找數(shù)據(jù)表中數(shù)據(jù)的方式介紹一下B+樹索引查找數(shù)據(jù)方法。

利用聚集索引查找數(shù)據(jù) 

還是這張B+樹索引圖,現(xiàn)在我們應(yīng)該知道這就是聚集索引,表中的數(shù)據(jù)存儲在其中。現(xiàn)在假設(shè)我們要查找id>=18并且id<40的用戶數(shù)據(jù)。對應(yīng)的sql語句為select * from user where id>=18 and id <40,其中id為主鍵。具體的查找過程如下: 

1. 一般根節(jié)點(diǎn)都是常駐內(nèi)存的,也就是說頁1已經(jīng)在內(nèi)存中了,此時不需要到磁盤中讀取數(shù)據(jù),直接從內(nèi)存中讀取即可。

          從內(nèi)存中讀取到頁1,要查找這個id>=18 and id <40或者范圍值,我們首先需要找到id=18的鍵值。

          從頁1中我們可以找到鍵值18,此時我們需要根據(jù)指針p2,定位到頁3。

2. 要從頁3中查找數(shù)據(jù),我們就需要拿著p2指針去磁盤中進(jìn)行讀取頁3。

          從磁盤中讀取頁3后將頁3放入內(nèi)存中,然后進(jìn)行查找,我們可以找到鍵值18,然后再拿到頁3中的指針p1,定位到頁8。

3. 同樣的頁8頁不在內(nèi)存中,我們需要再去磁盤中將頁8讀取到內(nèi)存中。

          將頁8讀取到內(nèi)存中后。

          因?yàn)轫撝械臄?shù)據(jù)是鏈表進(jìn)行連接的,而且鍵值是按照順序存放的,此時可以根據(jù)二分查找法定位到鍵值18。

          此時因?yàn)橐呀?jīng)到數(shù)據(jù)頁了,此時我們已經(jīng)找到一條滿足條件的數(shù)據(jù)了,就是鍵值18對應(yīng)的數(shù)據(jù)。

          因?yàn)槭欠秶檎遥掖藭r所有的數(shù)據(jù)又都存在葉子節(jié)點(diǎn),并且是有序排列的,那么我們就可以對頁8中的鍵值依次進(jìn)行遍歷查找并匹配滿足條件的數(shù)據(jù)。

          我們可以一直找到鍵值為22的數(shù)據(jù),然后頁8中就沒有數(shù)據(jù)了,此時我們需要拿著頁8中的p指針去讀取頁9中的數(shù)據(jù)。

4. 因?yàn)轫?不在內(nèi)存中,就又會加載頁9到內(nèi)存中,并通過和頁8中一樣的方式進(jìn)行數(shù)據(jù)的查找,直到將頁12加載到內(nèi)存中,發(fā)現(xiàn)41大于40,此時不滿足條件。

          那么查找到此終止。

最終我們找到滿足條件的所有數(shù)據(jù)為:

(18,kl),(19,kl),(22,hj),(24,io),(25,vg),(29,jk),(31,jk),(33,rt),(34,ty),(35,yu),(37,rt),(39,rt)。

總共12條記錄。

下面看下具體的查找流程圖:

 

利用非聚集索引查找數(shù)據(jù) 

 

讀者看到這張圖的時候可能會蒙,這是啥東西啊?怎么都是數(shù)字。 

如果有這種感覺,請仔細(xì)看下圖中紅字的解釋。什么?還看不懂?那我再來解釋下吧。首先,這個非聚集索引表示的是用戶幸運(yùn)數(shù)字的索引(為什么是幸運(yùn)數(shù)字?一時興起想起來的:-)),此時表結(jié)構(gòu)是這樣的。 

id name luckyNum
1 zs 23
2 ls 7

在葉子節(jié)點(diǎn)中,不在存儲所有的數(shù)據(jù)了,存儲的是鍵值和主鍵。

對于葉子節(jié)點(diǎn)中的x-y,比如1-1。左邊的1表示的是索引的鍵值,右邊的1表示的是主鍵值。如果我們要找到幸運(yùn)數(shù)字為33的用戶信息,對應(yīng)的sql語句為select * from user where luckNum=33。

查找的流程跟聚集索引一樣,這里就不詳細(xì)介紹了。我們最終會找到主鍵值47,找到主鍵后我們需要再到聚集索引中查找具體對應(yīng)的數(shù)據(jù)信息,此時又回到了聚集索引的查找流程。

下面看下具體的查找流程圖:

 

在MyISAM中,聚集索引和非聚集索引的葉子節(jié)點(diǎn)都會存儲數(shù)據(jù)的文件地址。

總結(jié)

本篇文從二叉查找樹,詳細(xì)說明了為什么mysql用B+樹作為數(shù)據(jù)的索引,以及在innodb中數(shù)據(jù)庫如何通過B+樹索引來存儲數(shù)據(jù)以及查找數(shù)據(jù)。我們一定要記住這就話:數(shù)據(jù)即索引,索引即數(shù)據(jù)。

 

責(zé)任編輯:龐桂玉 來源: Hollis
相關(guān)推薦

2019-11-05 14:06:07

MySQLB+索引

2018-08-07 16:01:32

synchronizevolatilefinal

2022-09-26 10:09:08

MVCC控制并發(fā)

2021-02-22 13:32:19

MySQLSQL索引

2020-12-11 08:23:06

JavaMemory Mode內(nèi)存模型

2018-07-03 14:54:25

Java內(nèi)存模型

2021-05-31 09:42:48

MySQL隔離級別

2018-12-07 09:31:52

分布式鎖服務(wù)框架分布式系統(tǒng)

2022-11-08 09:33:36

訂單系統(tǒng)電商

2019-09-19 14:03:32

B樹節(jié)點(diǎn)數(shù)據(jù)結(jié)構(gòu)

2022-05-23 09:41:27

分庫分表數(shù)據(jù)庫算法

2021-03-08 12:47:42

MySQL查詢數(shù)據(jù)

2021-03-08 10:25:37

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

2022-10-21 16:39:56

JDK優(yōu)化

2022-03-28 08:24:52

MySQL聚簇索引非聚簇索引

2023-12-11 08:32:58

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

2019-09-24 09:33:53

MySQLB+樹InnoDB

2024-05-22 09:01:53

InnoDBB+索引

2025-11-03 16:30:44

2020-04-20 13:11:21

HashMap底層存儲
點(diǎn)贊
收藏

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

日韩av在线影院| 一区二区三区丝袜| 国产中文字幕亚洲| 五月天激情丁香| jizz国产精品| 日本韩国一区二区三区| 宅男一区二区三区| 色欲av永久无码精品无码蜜桃| 久久久久久亚洲精品杨幂换脸| 久久精品国产一区| 日韩精品视频一区二区| 成人亚洲网站| 午夜私人影院久久久久| 一区二区三区四区视频在线观看 | 一区二区三区国产盗摄| 夜夜嗨av色一区二区不卡| 伦伦影院午夜理论片| 日韩免费小视频| 亚洲国产你懂的| 一区二区三区视频在线播放| 天堂av资源网| 国产一区二区三区四| 国产成人精品免高潮在线观看| 国产第一页浮力| 久久av中文| 精品美女在线播放| 一级黄色在线播放| 亚洲精品一区三区三区在线观看| 亚洲成a人在线观看| 一区二区高清视频| 大胆av不用播放器在线播放 | v片在线观看| 日本一区二区三区在线观看| 好看的日韩精品| 精品国产亚洲一区二区麻豆| 蜜桃一区二区三区在线| 欧美有码在线观看视频| 国产在线免费视频| 欧美国产高潮xxxx1819| 不卡av电影院| h色网站在线观看| 久久精品高清| 国产小视频91| 国产免费看av| 你懂的视频欧美| 日韩毛片中文字幕| 国产精品嫩草av| 高清一区二区三区| 欧美变态口味重另类| 91精品国产三级| 国产精品日本一区二区不卡视频| 精品视频在线免费| 日本免费观看网站| 国精产品一区一区三区四川| 色哟哟一区二区三区| www.国产区| 欧美xxx网站| 色偷偷久久一区二区三区| 一本大道熟女人妻中文字幕在线| 麻豆mv在线看| 色婷婷综合激情| 嫩草av久久伊人妇女超级a| 国产精品av一区二区三区| 欧美视频中文在线看| 国产精品宾馆在线精品酒店| 在线观看v片| 色婷婷一区二区| 亚洲国产精品三区| 四虎成人精品一区二区免费网站| 欧美一区二区视频网站| 超碰人人cao| 精品亚洲免a| 亚洲欧美精品在线| 激情五月深爱五月| 亚洲国产精品成人| 国内精品视频在线| 美女又爽又黄免费视频| 青青草原综合久久大伊人精品优势| 国产精品美乳在线观看| 国产精品久久影视| 国产成人综合精品三级| 久久精品日韩| avtt亚洲| 亚洲综合免费观看高清在线观看| 三上悠亚久久精品| 亚洲精品555| 欧美大片顶级少妇| 瑟瑟视频在线观看| 香蕉国产精品| 91精品国产乱码久久久久久蜜臀| 日韩一级片中文字幕| 国产一区二区视频在线播放| 国语精品免费视频| 一区二区高清不卡| 亚洲国产精品影院| 牛夜精品久久久久久久| 1313精品午夜理伦电影| 亚洲天堂网站在线观看视频| 一级黄色录像视频| 老司机一区二区三区| 成人在线视频福利| 丝袜+亚洲+另类+欧美+变态| 国产精品传媒入口麻豆| 青青草国产免费| 国产精品美女午夜爽爽| 亚洲国产另类 国产精品国产免费| 少妇人妻好深好紧精品无码| 欧美日韩国产一区精品一区| 国产精品爱啪在线线免费观看 | 精品一二线国产| 久久99精品久久久久久水蜜桃| 色哟哟免费在线观看| 富二代精品短视频| 无码人妻久久一区二区三区蜜桃| 精品国产一区二区三区久久久樱花| 欧美成人精品激情在线观看 | 日韩激情一二三区| 国产精品theporn88| 午夜视频在线看| 午夜私人影院久久久久| 深夜做爰性大片蜜桃| 波多野结衣的一区二区三区 | 99热国产在线观看| 国产黄色91视频| 亚洲乱码一区二区三区| 中文字幕在线视频网站| 日韩精品中文字幕一区二区三区| 亚洲色图100p| 日本免费在线视频不卡一不卡二| 国产日韩精品一区观看| 国产精品久久久久久福利| 欧美丝袜第一区| 人妻激情偷乱频一区二区三区| 麻豆av一区二区三区| 牛牛电影国产一区二区| 91麻豆精品国产91久久久更新时间| 免费毛片视频网站| 国产欧美一区二区三区国产幕精品| 91九色在线观看| 免费观看在线午夜影视| 欧美日韩亚洲综合在线 | heyzo久久| 欧美一区二区色| 天天操天天射天天| 亚洲国产精品一区二区久久恐怖片| 在线免费看v片| 久久久久久久久久久9不雅视频| 国产精品揄拍一区二区| jizz在线观看中文| 欧美日韩综合一区| 激情高潮到大叫狂喷水| 久久精品国产久精国产| 五月天久久综合网| 欧美国产视频| 成人97在线观看视频| 国产乱淫片视频| 亚洲欧美一区二区不卡| 在线观看中文av| 久久久久亚洲| http;//www.99re视频| 欧美24videosex性欧美| 亚洲二区在线播放视频| 天天爽夜夜爽夜夜爽精品| 91蜜桃婷婷狠狠久久综合9色| 18岁网站在线观看| 国产日产精品一区二区三区四区的观看方式| 91chinesevideo永久地址| 日本视频在线观看一区二区三区| 色综合天天综合给合国产| 日本爱爱爱视频| 精品一区中文字幕| 成人区一区二区| 婷婷精品在线观看| 国产精品99免视看9| 在线观看美女网站大全免费| 欧美一区二视频| 国产极品在线播放| 久久久亚洲综合| 国产一区二区在线观看免费视频| 欧美1区3d| 久久天天狠狠| 国产成人亚洲一区二区三区| 欧美成人小视频| 五月婷婷激情在线| 欧美性猛片aaaaaaa做受| 久久爱一区二区| 成人国产亚洲欧美成人综合网| 男人亚洲天堂网| 亚洲国产成人精品女人| 久久久久久久久久久久久9999| 国产一区影院| 久久久久成人网| 国产区在线视频| 精品少妇一区二区三区日产乱码 | 九九九九九精品| 国产精品第一| 久久青草福利网站| 欧美成人精品一区二区男人看| 精品国产免费人成电影在线观看四季 | 久久久久久久久久久网站| 男操女在线观看| 91精品久久久久久久91蜜桃| 六月丁香激情综合| 亚洲男人天堂一区| 伊人网伊人影院| 国产成人av一区二区三区在线 | 国产在线视频一区二区| 噜噜噜久久亚洲精品国产品麻豆| 水蜜桃久久夜色精品一区| 精品一区二区日本| 日韩精品一级| 国产精品久久久| 白浆在线视频| 美女久久久久久久| a√资源在线| 亚洲精品一区二区在线| 精品人妻无码一区二区色欲产成人| 91福利国产精品| 日韩三级视频在线| 伊人一区二区三区| 日本裸体美女视频| 久久久99免费| 一区二区视频观看| 高清不卡一区二区在线| 国产免费中文字幕| 秋霞午夜鲁丝一区二区老狼| 91视频最新入口| 亚洲国产专区校园欧美| 青青青在线观看视频| 亚洲第一天堂| 国产免费色视频| 久久影院一区| 亚洲欧美日韩另类精品一区二区三区| 美女久久99| 欧美三级网色| 亚欧日韩另类中文欧美| 国精产品一区二区| 国产精品18hdxxxⅹ在线| 99精品国产高清在线观看| 成人在线日韩| 91久久国产婷婷一区二区| 国精品产品一区| 国产精品影片在线观看| 福利一区在线| 成人激情视频小说免费下载| 国产欧美在线观看免费| 国产一区红桃视频| 97精品资源在线观看| 成人h视频在线| 日韩在线激情| 成人黄色大片在线免费观看| 日韩亚洲国产免费| 91精品在线国产| 精品国产亚洲一区二区三区在线 | 亚洲人成网站影音先锋播放| 国产视频123区| 国产精品久久久久久久久免费相片 | 免费黄色一级大片| 精品视频1区2区| 92久久精品一区二区| 欧美视频在线一区| 国产精品久久久久久免费免熟| 欧美久久久久久蜜桃| 国产免费无遮挡| 精品久久久久一区二区国产| 刘亦菲久久免费一区二区| 日韩成人中文电影| 国产最新视频在线观看| 色综合伊人色综合网站| 国产黄大片在线观看画质优化| 九九久久综合网站| 神马久久午夜| 国产精品美女www爽爽爽视频| 日韩美女在线| 成人91视频| 亚洲8888| 亚洲欧美精品| 狠狠爱综合网| 丁香啪啪综合成人亚洲| 精品在线观看免费| 免费黄色三级网站| 国产精品午夜在线观看| 欧美一区二区三区爽爽爽| 婷婷国产在线综合| 中文人妻熟女乱又乱精品| 日韩欧美专区在线| 青青操在线视频| 久久久www成人免费精品| av在线播放资源| 国产精品一区电影| 久草在线综合| 一本色道久久99精品综合| 亚洲第一毛片| 亚洲精品久久久中文字幕| 国产盗摄视频一区二区三区| 人妻少妇一区二区| 一区二区三区四区五区视频在线观看| 亚洲第一精品在线观看| 69堂亚洲精品首页| 日韩精品系列| 欧美高清第一页| 九九久久国产| 久久久久久久久久久久久久一区| 国产精品99久久| 99精品视频播放| 国产成人av影院| 天天做夜夜爱爱爱| 色综合一区二区| 亚洲精品视频91| 啊v视频在线一区二区三区| 欧美裸体视频| 亚洲最大福利视频网| 成人黄色av| 红桃av在线播放| 成人免费av资源| 永久免费看片视频教学| 一本高清dvd不卡在线观看| 成人午夜福利视频| 久久深夜福利免费观看| 日韩国产网站| 久久久久久久久久久久久久一区 | 欧美中文字幕第一页| 97视频一区| 影音先锋成人资源网站| 蜜桃视频在线观看一区二区| 精品人妻互换一区二区三区| 精品动漫一区二区| 免费a视频在线观看| 蜜臀久久99精品久久久无需会员| 日本中文字幕视频一区| 日本精品国语自产拍在线观看| 国产一区二区三区的电影| 人妻 日韩 欧美 综合 制服| 依依成人精品视频| 精品久久久中文字幕人妻| 日韩亚洲欧美中文在线| 国产第一精品| 亚洲蜜桃av| 麻豆精品视频在线观看免费| 一级肉体全黄裸片| 色欧美日韩亚洲| 四虎在线免费观看| 91成人在线观看国产| 欧美男男freegayvideosroom| 国产不卡一区二区视频| www.欧美日韩| 99久在线精品99re8热| 日韩久久午夜影院| 成人性教育av免费网址| 麻豆亚洲一区| 久久久综合网| 久久久视频6r| 欧美午夜电影网| 日本三级视频在线播放| 91在线观看免费高清完整版在线观看 | 激情偷乱视频一区二区三区| 精品无码一区二区三区蜜臀| 69av一区二区三区| 日韩免费影院| 国产在线一区二区三区欧美| 另类av一区二区| 手机看片国产日韩| 91精品国产综合久久久久久| 免费电影网站在线视频观看福利| 国产区欧美区日韩区| 久久都是精品| 国产白丝一区二区三区| 欧美一区二区三区系列电影| 日本h片在线| 欧美精品123| 久久66热re国产| 国产亚洲欧美精品久久久www| 亚洲福利视频网站| 高清av不卡| 亚洲一区二区三区涩| 国产毛片一区二区| 日本一区二区免费在线观看| 国产亚洲精品美女久久久| 99亚洲男女激情在线观看| www.avtt| 国产欧美中文在线| 国产免费黄色网址| 17婷婷久久www| 98精品视频| 国产免费一区二区三区最新6| 日本丶国产丶欧美色综合| 黄色片网站在线观看| 国内精品二区| 美女一区二区三区在线观看| 久草中文在线视频| 国产亚洲精品91在线| 8x国产一区二区三区精品推荐| 激情五月开心婷婷| 亚洲免费在线观看视频| 日韩私人影院| 亚洲一区二区在线| 久久一区亚洲| 久久综合综合久久| 日韩网站在线观看| 欧美重口另类|