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

終于有篇看的懂的B樹文章了!

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

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

[[282139]] 

圖片來自 Pexels

索引是一種數據結構,用于幫助我們在大量數據中快速定位到我們想要查找的數據。

索引最形象的比喻就是圖書的目錄了。注意這里的大量,數據量大了索引才顯得有意義,如果我想要在 [1,2,3,4] 中找到 4 這個數據,直接對全數據檢索也很快,沒有必要費力氣建索引再去查找。

索引在 MySQL 數據庫中分三類:

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

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

要介紹 B+ 樹索引,就不得不提二叉查找樹,平衡二叉樹和 B 樹這三種數據結構。B+ 樹就是從他們仨演化來的。

二叉查找樹

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

 

從圖中可以看到,我們為 user 表(用戶信息表)建立了一個二叉查找樹的索引。

圖中的圓為二叉查找樹的節點,節點中存儲了鍵(key)和數據(data)。鍵對應 user 表中的 id,數據對應 user 表中的行數據。

二叉查找樹的特點就是任何節點的左子節點的鍵值都小于當前節點的鍵值,右子節點的鍵值都大于當前節點的鍵值。頂端的節點我們稱為根節點,沒有子節點的節點我們稱之為葉節點。

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

  • 將根節點作為當前節點,把 12 與當前節點的鍵值 10 比較,12 大于 10,接下來我們把當前節點>的右子節點作為當前節點。
  • 繼續把 12 和當前節點的鍵值 13 比較,發現 12 小于 13,把當前節點的左子節點作為當前節點。
  • 把 12 和當前節點的鍵值 12 對比,12 等于 12,滿足條件,我們從當前節點中取出 data,即 id=12,name=xm。

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

平衡二叉樹

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

 

這個時候可以看到我們的二叉查找樹變成了一個鏈表。如果我們需要查找 id=17 的用戶信息,我們需要查找 7 次,也就相當于全表掃描了。

導致這個現象的原因其實是二叉查找樹變得不平衡了,也就是高度太高了,從而導致查找效率的不穩定。

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

平衡二叉樹又稱 AVL 樹,在滿足二叉查找樹特性的基礎上,要求每個節點的左右子樹的高度差不能超過 1。

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

 

由平衡二叉樹的構造我們可以發現第一張圖中的二叉樹其實就是一棵平衡二叉樹。

平衡二叉樹保證了樹的構造是平衡的,當我們插入或刪除數據導致不滿足平衡二叉樹不平衡時,平衡二叉樹會進行調整樹上的節點來保持平衡。具體的調整方式這里就不介紹了。

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

B 樹

因為內存的易失性。一般情況下,我們都會選擇將 user 表中的數據和索引存儲在磁盤這種外圍設備中。

但是和內存相比,從磁盤中讀取數據的速度會慢上百倍千倍甚至萬倍,所以,我們應當盡量減少從磁盤中讀取數據的次數。

另外,從磁盤中讀取數據時,都是按照磁盤塊來讀取的,并不是一條一條的讀。

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

如果我們用樹這種數據結構作為索引的數據結構,那我們每查找一次數據就需要從磁盤中讀取一個節點,也就是我們說的一個磁盤塊。

我們都知道平衡二叉樹可是每個節點只存儲一個鍵值和數據的。那說明什么?說明每個磁盤塊僅僅存儲一個鍵值和數據!那如果我們要存儲海量的數據呢?

可以想象到二叉樹的節點將會非常多,高度也會極其高,我們查找數據時也會進行很多次磁盤 IO,我們查找數據的效率將會極低!

 

為了解決平衡二叉樹的這個弊端,我們應該尋找一種單個節點可以存儲多個鍵值和數據的平衡樹。也就是我們接下來要說的 B 樹。

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

 

圖中的 p 節點為指向子節點的指針,二叉查找樹和平衡二叉樹其實也有,因為圖的美觀性,被省略了。

圖中的每個節點稱為頁,頁就是我們上面說的磁盤塊,在 MySQL 中數據讀取的基本單位都是頁,所以我們這里叫做頁更符合 MySQL 中索引的底層數據結構。

從上圖可以看出,B 樹相對于平衡二叉樹,每個節點存儲了更多的鍵值(key)和數據(data),并且每個節點擁有更多的子節點,子節點的個數一般稱為階,上述圖中的 B 樹為 3 階 B 樹,高度也會很低。

基于這個特性,B 樹查找數據讀取磁盤的次數將會很少,數據的查找效率也會比平衡二叉樹高很多。

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

  • 先找到根節點也就是頁 1,判斷 28 在鍵值 17 和 35 之間,那么我們根據頁 1 中的指針 p2 找到頁 3。
  • 將 28 和頁 3 中的鍵值相比較,28 在 26 和 30 之間,我們根據頁 3 中的指針 p2 找到頁 8。
  • 將 28 和頁 8 中的鍵值相比較,發現有匹配的鍵值 28,鍵值 28 對應的用戶信息為(28,bv)。

B+ 樹

B+ 樹是對 B 樹的進一步優化。讓我們先來看下 B+ 樹的結構圖:

 

根據上圖我們來看下 B+ 樹和 B 樹有什么不同:

①B+ 樹非葉子節點上是不存儲數據的,僅存儲鍵值,而 B 樹節點中不僅存儲鍵值,也會存儲數據。

之所以這么做是因為在數據庫中頁的大小是固定的,InnoDB 中頁的默認大小是 16KB。

如果不存儲數據,那么就會存儲更多的鍵值,相應的樹的階數(節點的子節點樹)就會更大,樹就會更矮更胖,如此一來我們查找數據進行磁盤的 IO 次數又會再次減少,數據查詢的效率也會更快。

另外,B+ 樹的階數是等于鍵值的數量的,如果我們的 B+ 樹一個節點可以存儲 1000 個鍵值,那么 3 層 B+ 樹可以存儲 1000×1000×1000=10 億個數據。

一般根節點是常駐內存的,所以一般我們查找 10 億數據,只需要 2 次磁盤 IO。

②因為 B+ 樹索引的所有數據均存儲在葉子節點,而且數據是按照順序排列的。

那么 B+ 樹使得范圍查找,排序查找,分組查找以及去重查找變得異常簡單。而 B 樹因為數據分散在各個節點,要實現這一點是很不容易的。

有心的讀者可能還發現上圖 B+ 樹中各個頁之間是通過雙向鏈表連接的,葉子節點中的數據是通過單向鏈表連接的。

其實上面的 B 樹我們也可以對各個節點加上鏈表。這些不是它們之前的區別,是因為在 MySQL 的 InnoDB 存儲引擎中,索引就是這樣存儲的。

也就是說上圖中的 B+ 樹索引就是 InnoDB 中 B+ 樹索引真正的實現方式,準確的說應該是聚集索引(聚集索引和非聚集索引下面會講到)。

通過上圖可以看到,在 InnoDB 中,我們通過數據頁之間通過雙向鏈表連接以及葉子節點中數據之間通過單向鏈表連接的方式可以找到表中所有的數據。

MyISAM 中的 B+ 樹索引實現與 InnoDB 中的略有不同。在 MyISAM 中,B+ 樹索引的葉子節點并不存儲數據,而是存儲數據的文件地址。

聚集索引 VS 非聚集索引

在上節介紹 B+ 樹索引的時候,我們提到了圖中的索引其實是聚集索引的實現方式。

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

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

①聚集索引(聚簇索引):以 InnoDB 作為存儲引擎的表,表中的數據都會有一個主鍵,即使你不創建主鍵,系統也會幫你創建一個隱式的主鍵。

這是因為 InnoDB 是把數據存放在 B+ 樹中的,而 B+ 樹的鍵值就是主鍵,在 B+ 樹的葉子節點中,存儲了表中所有的數據。

這種以主鍵作為 B+ 樹索引的鍵值而構建的 B+ 樹索引,我們稱之為聚集索引。

②非聚集索引(非聚簇索引):以主鍵以外的列值作為鍵值構建的 B+ 樹索引,我們稱之為非聚集索引。

非聚集索引與聚集索引的區別在于非聚集索引的葉子節點不存儲表中的數據,而是存儲該列對應的主鍵,想要查找數據我們還需要根據主鍵再去聚集索引中進行查找,這個再根據聚集索引查找數據的過程,我們稱為回表。

明白了聚集索引和非聚集索引的定義,我們應該明白這樣一句話:數據即索引,索引即數據。

利用聚集索引和非聚集索引查找數據

前面我們講解 B+ 樹索引的時候并沒有去說怎么在 B+ 樹中進行數據的查找,主要就是因為還沒有引出聚集索引和非聚集索引的概念。

下面我們通過講解如何通過聚集索引以及非聚集索引查找數據表中數據的方式介紹一下 B+ 樹索引查找數據方法。

利用聚集索引查找數據

 

還是這張 B+ 樹索引圖,現在我們應該知道這就是聚集索引,表中的數據存儲在其中。

現在假設我們要查找 id>=18 并且 id<40 的用戶數據。對應的 sql 語句為:

  1. select * from user where id>=18 and id <40 

其中 id 為主鍵,具體的查找過程如下:

①一般根節點都是常駐內存的,也就是說頁 1 已經在內存中了,此時不需要到磁盤中讀取數據,直接從內存中讀取即可。

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

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

②要從頁 3 中查找數據,我們就需要拿著 p2 指針去磁盤中進行讀取頁 3。

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

③同樣的頁 8 頁不在內存中,我們需要再去磁盤中將頁 8 讀取到內存中。

將頁 8 讀取到內存中后。因為頁中的數據是鏈表進行連接的,而且鍵值是按照順序存放的,此時可以根據二分查找法定位到鍵值 18。

此時因為已經到數據頁了,此時我們已經找到一條滿足條件的數據了,就是鍵值 18 對應的數據。

因為是范圍查找,而且此時所有的數據又都存在葉子節點,并且是有序排列的,那么我們就可以對頁 8 中的鍵值依次進行遍歷查找并匹配滿足條件的數據。

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

④因為頁 9 不在內存中,就又會加載頁 9 到內存中,并通過和頁 8 中一樣的方式進行數據的查找,直到將頁 12 加載到內存中,發現 41 大于 40,此時不滿足條件。那么查找到此終止。

最終我們找到滿足條件的所有數據,總共 12 條記錄:

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

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

利用非聚集索引查找數據

 

讀者看到這張圖的時候可能會蒙,這是啥東西啊?怎么都是數字。如果有這種感覺,請仔細看下圖中紅字的解釋。

什么?還看不懂?那我再來解釋下吧。首先,這個非聚集索引表示的是用戶幸運數字的索引(為什么是幸運數字?一時興起想起來的:-)),此時表結構是這樣的。

 

在葉子節點中,不再存儲所有的數據了,存儲的是鍵值和主鍵。對于葉子節點中的 x-y,比如 1-1。左邊的 1 表示的是索引的鍵值,右邊的 1 表示的是主鍵值。

如果我們要找到幸運數字為 33 的用戶信息,對應的 sql 語句為:

  1. select * from user where luckNum=33 

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

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

在 MyISAM 中,聚集索引和非聚集索引的葉子節點都會存儲數據的文件地址。

總結

本篇文章從二叉查找樹,詳細說明了為什么 MySQL 用 B+ 樹作為數據的索引,以及在 InnoDB 中數據庫如何通過 B+ 樹索引來存儲數據以及查找數據。

我們一定要記住這句話:數據即索引,索引即數據。

參考資料:

《MySQL 必知必會》

《MySQL 技術內幕 InnoDB 存儲引擎第2版》

https://www.cnblogs.com/vianzhang/p/7922426.html

http://blog.codinglabs.org/articles/theory-of-mysql-index.html

責任編輯:武曉燕 來源: Hollis
相關推薦

2024-02-27 14:27:16

2023-07-31 09:12:39

B+樹節點B+Tree

2019-09-19 14:03:32

B樹節點數據結構

2021-12-14 17:19:15

存儲數據

2020-08-06 16:55:37

虛擬化底層計算機

2021-07-26 05:00:16

算法DfsBfs

2021-12-13 20:09:33

GoElasticsearJava

2023-05-12 09:08:48

TypeScript工具類型

2020-09-21 08:33:12

線程池調度Thread Pool

2020-04-20 10:33:56

戴爾

2021-10-29 15:44:11

鴻蒙HarmonyOS應用

2022-12-31 08:17:02

2023-11-02 08:43:08

protocgo兼容

2025-11-07 00:00:00

2020-05-09 14:40:29

UI設計開發

2017-12-26 11:00:17

iPhone果粉安卓

2025-07-16 18:00:45

AI 音頻產品AI 工具

2018-09-28 14:28:28

MySQL存儲過程

2021-07-15 09:55:47

systemdLinux文件

2020-03-30 17:20:54

B+樹SQL索引
點贊
收藏

51CTO技術棧公眾號

91电影在线播放| 亚洲精品一区二区二区| 国产一区二区三区不卡av| 欧美日韩一区二区在线播放| 深夜福利成人| 不卡视频在线播放| 丝袜美腿亚洲一区| 欧美激情a∨在线视频播放| 艳妇乳肉亭妇荡乳av| 精品久久99| 婷婷亚洲久悠悠色悠在线播放 | 污污的视频免费| 草美女在线观看| 国产精品欧美精品| 九九热久久66| 国产深喉视频一区二区| 老司机精品视频网站| 欧美精品激情视频| 老司机深夜福利网站| 任你弄精品视频免费观看| 宅男噜噜噜66一区二区66| 国产l精品国产亚洲区久久| 国产网站在线免费观看| 久久久久久夜精品精品免费| 99久久一区三区四区免费| 中文字幕乱码中文字幕| 日韩亚洲国产欧美| 欧美精品在线视频观看| 欧美美女性生活视频| 亚洲丝袜啪啪| 亚洲国产精品热久久| 一级日本黄色片| 国产综合色激情| 色婷婷精品久久二区二区蜜臀av| 每日在线观看av| 综合图区亚洲| 国产精品久久久久久久久免费桃花 | 少妇激情综合网| 爱爱免费小视频| 国产精品xxxav免费视频| 制服视频三区第一页精品| 亚洲色图久久久| 成人mm视频在线观看| 色综合一区二区| 免费黄色福利视频| 日韩av一卡| 精品日韩中文字幕| 国产原创popny丨九色| 日本无删减在线| 亚洲精品五月天| 天天想你在线观看完整版电影免费| 欧美成人精品一区二区男人看| 国产精品久久久久久久午夜片| 涩涩涩999| 在线激情网站| 国产精品欧美一区喷水| 亚洲一区二区三区精品动漫| 亚洲黄色有码视频| 久久无码人妻精品一区二区三区| 欧美高清视频看片在线观看| 日韩精品视频免费专区在线播放| 中文字幕5566| 国产剧情一区| 色777狠狠综合秋免鲁丝| 亚洲色图27p| 围产精品久久久久久久| 久久国产精品久久精品| 国产一级视频在线| 999亚洲国产精| 国产ts人妖一区二区三区| 日韩电影在线观看一区二区| 美女视频黄频大全不卡视频在线播放| 国产精品一区二区三区免费视频| 国产精品亚洲lv粉色| 国产盗摄精品一区二区三区在线| 国产另类自拍| 国产视频福利在线| 亚洲欧洲在线观看av| 国产一区二区三区在线免费| 国产美女高潮在线| 欧美亚日韩国产aⅴ精品中极品| 午夜剧场在线免费观看| 视频一区日韩精品| 亚洲男人天天操| 婷婷国产成人精品视频| 亚洲欧洲一区| 国产精品免费久久久久影院| 国产日韩精品suv| 9久草视频在线视频精品| 色婷婷精品国产一区二区三区| 婷婷免费在线视频| 亚洲二区在线观看| 天天操天天爽天天射| 日本精品在线播放 | www.中文字幕久久久| **性色生活片久久毛片| 国产白丝袜美女久久久久| 欧美亚洲黄色| 欧美成人免费网站| 99久久精品免费视频| 亚洲午夜精品一区二区国产| 欧美中文在线视频| 国产日韩欧美视频在线观看| 91麻豆国产在线观看| 只有这里有精品| 亚洲女同av| 日韩免费福利电影在线观看| 老头老太做爰xxx视频| 亚洲午夜伦理| 国产精品一二三在线| 少妇精品视频一区二区| 日韩久久一区二区| 亚洲国产精品毛片av不卡在线| 日韩在线观看一区二区三区| 这里只有视频精品| 少妇一级淫片免费放中国 | 日本少妇xxxx| 午夜精品久久久久久久四虎美女版| 69**夜色精品国产69乱| 99热这里只有精品66| 国产精品三级在线观看| 国产精品免费观看久久| avtt综合网| 久久中文字幕一区| 亚洲一卡二卡在线| 久久精品一二三| 欧美亚洲精品一区二区| 99精品国产一区二区三区2021| 久久精品视频在线观看| 日本一区二区三区久久| 久久久久久久久久久黄色| 国产精品网站免费| 国产主播性色av福利精品一区| 久久综合色88| 国产伦理吴梦梦伦理| 国产精品久线观看视频| 中文字幕永久视频| 成人综合一区| 国产精品私拍pans大尺度在线 | 久久亚洲一区二区三区四区五区高| 欧美特级黄色片| 久久久噜噜噜久久人人看| 国产成人精品视频免费看| 成人盗摄视频| 国内免费久久久久久久久久久| 亚洲黄色在线观看视频| 亚洲一区二区三区四区五区黄| 色综合久久久无码中文字幕波多| 亚洲国产日韩欧美在线| 亚洲一区二区三区在线视频| 国产视频中文字幕在线观看| 欧美一级淫片007| 青娱乐在线视频免费观看| 国产成人综合亚洲网站| 国产精品视频一二三四区| 亚洲**毛片| 韩国国内大量揄拍精品视频| 四虎永久在线观看| 欧美日韩亚洲系列| 国产传媒国产传媒| 美女在线一区二区| 91免费视频黄| 99国产精品久久一区二区三区| 亚州成人av在线| 日本一区高清| 欧美网站一区二区| 成人在线观看免费完整| 高清在线不卡av| 乱妇乱女熟妇熟女网站| 欧美日韩在线网站| 成人有码视频在线播放| 欧美xxxx性xxxxx高清| 亚洲激情成人网| 中文字幕手机在线视频| 中文字幕五月欧美| 亚洲中文字幕无码一区| 性感少妇一区| 一本一生久久a久久精品综合蜜| 国产精品日本一区二区不卡视频| 久久久久久久久久久免费| 欧美亚洲日本| 91精品国产福利| 日韩女同强女同hd| 中文字幕亚洲在| 五月天丁香社区| 日韩vs国产vs欧美| 白白操在线视频| 神马电影久久| 5g影院天天爽成人免费下载| 一区二区三区短视频| 久久精品国产欧美亚洲人人爽| 黄色美女一级片| 欧美在线影院一区二区| 久久久国产精品黄毛片| 日本一区二区三区高清不卡| 午夜福利三级理论电影| 久久一区欧美| 隔壁人妻偷人bd中字| 国产一区二区三区四区二区| yy111111少妇影院日韩夜片| 丝袜美腿一区| 久久久久久久亚洲精品| 免费在线你懂的| 亚洲精品视频在线观看视频| 欧美激情一区二区视频| 久久综合伊人| avove在线观看| 亚洲美女久久| 一区二区三区中文字幕电影| 国产香蕉精品视频| 免费在线看成人av| 无罩大乳的熟妇正在播放| 五月天综合网站| 日韩免费三级| 欧美成a人免费观看久久| 亚洲一区二区三区视频播放| 91精品店在线| 日本一区二区在线播放| 888av在线视频| 美女精品视频一区| 在线国产情侣| 国产亚洲精品一区二555| 神马久久久久| 亚洲电影第1页| 亚洲大尺度网站| 日韩一级在线观看| 国产毛片在线视频| 欧美日韩一卡二卡三卡| 亚洲第一网站在线观看| 欧美日韩中文字幕在线| 精品无码黑人又粗又大又长| 亚洲免费观看高清| 伊人久久久久久久久久久久久久| 欧美激情资源网| 成人午夜福利一区二区| 久久午夜羞羞影院免费观看| 亚洲午夜久久久久久久久| 国产成人亚洲精品青草天美| 在线a免费观看| 国产精品亚洲第一 | 日韩av中文字幕一区二区| 1024精品视频| 亚洲一区不卡| 欧美日韩亚洲一| 久久久久91| 99热成人精品热久久66| 久久久蜜桃一区二区人| 成年人免费大片| 久久蜜桃精品| 国产视频手机在线播放| 日韩中文欧美在线| 国产精品久久久毛片| 久久99热狠狠色一区二区| 在线观看免费av网址| 国产乱人伦偷精品视频不卡 | ww久久中文字幕| 久久精品一区二区免费播放| 久久久亚洲欧洲日产国码αv| 中文字幕被公侵犯的漂亮人妻| 久久久久9999亚洲精品| 婷婷综合在线视频| 亚洲欧洲日韩女同| 青青操视频在线播放| 亚洲国产精品嫩草影院| 久久亚洲天堂网| 色噜噜狠狠成人中文综合| 一区二区视频免费| 欧美一区二区视频在线观看2022 | 日韩在线电影一区| 91九色精品| 免费看欧美黑人毛片| 久久裸体视频| 亚洲欧美日韩网站| 成人91在线观看| 男女做爰猛烈刺激| 日韩毛片精品高清免费| 国产性生活网站| 在线观看成人小视频| 国产乱码久久久久| 亚洲国产欧美一区| 91精彩视频在线观看| 久久99热精品| 日韩电影免费观| 亚洲自拍偷拍网址| 伊人久久大香线蕉综合网蜜芽| 亚洲成色www久久网站| 国产精品99免费看| 91视频免费版污| 国产成人精品在线看| 亚洲综合色一区| 亚洲九九爱视频| 无码人妻丰满熟妇区五十路| 91精品国产综合久久久久久久 | 伊人久久大香线蕉av一区二区| www视频在线看| 欧洲成人午夜免费大片| 国产在线不卡一区二区三区| 鲁片一区二区三区| 欧美国产综合| 少妇网站在线观看| 99久久国产综合色|国产精品| 香蕉成人在线视频| 欧美视频免费在线| 亚洲国产欧美另类| 色av中文字幕一区| 日韩电影大全网站| 精品毛片久久久久久| 欧美激情视频一区二区三区免费| 欧美xxxxx在线视频| 盗摄精品av一区二区三区| 国产99在线 | 亚洲| 婷婷综合在线观看| 亚洲免费成人在线| 久久综合伊人77777尤物| 日日av拍夜夜添久久免费| 国产高清在线精品一区二区三区| 999久久久免费精品国产| 精品一卡二卡三卡| 成人av资源站| 青青草原在线免费观看| 精品视频一区 二区 三区| 国产尤物视频在线| 欧美一区二三区| 老汉色老汉首页av亚洲| 日韩成人三级视频| 国产毛片一区二区| 免费成人美女女在线观看| 日本道在线观看一区二区| 四虎在线视频| 91精品国产91久久久久福利| 大奶在线精品| 久久亚洲a v| 国产成a人无v码亚洲福利| 国产稀缺精品盗摄盗拍| 欧美人与z0zoxxxx视频| av在线资源站| 国产精品欧美日韩一区二区| 国产伦精品一区二区三区视频 | 国产精品美女毛片真酒店| 日韩欧美一级二级三级| 久cao在线| 亚洲精品欧美日韩专区| 一区二区影视| www.色.com| 一区二区三区成人| 亚洲av无码国产精品久久不卡| 久久69精品久久久久久久电影好 | 免费精品在线视频| 欧美区视频在线观看| 欧美激情视频在线播放| 91久久久在线| 欧美三级小说| 欧美日韩人妻精品一区在线| 欧美日韩性视频在线| 欧美孕妇孕交| 国产欧美一区二区三区在线| 99久久夜色精品国产亚洲狼| 熟妇无码乱子成人精品| 一区二区三区免费网站| 欧美一级在线免费观看| 欧美又大粗又爽又黄大片视频| 国产精品欧美在线观看| 少妇一级淫免费播放| 亚洲日本成人在线观看| 亚洲精品无amm毛片| 91精品国产色综合久久不卡98口 | 丰满女人性猛交| 国产成人综合网站| 毛片视频网站在线观看| 一区二区三区亚洲| 美女国产精品久久久| r级无码视频在线观看| 久久久亚洲综合| 国产伦精品一区二区三区免.费| 欧美黄网免费在线观看| 国产乱码精品一区二区亚洲| 日韩欧美中文在线视频| 午夜成人免费电影| 3p在线观看| 国产精品久久久久av福利动漫| 久久精品官网| 一区二区视频免费看| 日韩成人中文字幕| 玖玖精品在线| 久久久性生活视频| 国产精品水嫩水嫩| 欧美一区二区三区激情| 国产精品久久91| 激情亚洲网站| 欧洲性xxxx| 亚洲精品v天堂中文字幕| 色猫猫成人app| 日本一道本久久| 亚洲欧洲无码一区二区三区| 四虎精品在线| 亚洲free嫩bbb| 日本va欧美va精品发布| 国产中文字幕免费| 播播国产欧美激情| 亚洲警察之高压线|