亭亭五月天在线观看,亭亭五月天在线观看,国产最新av一区二区,国产 高清 中文字幕,99re热久久亚洲综合精品成人,熟妇 一区二区三区,一级做a爰片性色毛片武则天,美女的骚穴视频播放,国产美女午夜免费视频

首頁(yè)>國(guó)內(nèi) > 正文

聚集索引和非聚集索引,很簡(jiǎn)單的面試題,但是很多人都不知道

2023-06-05 13:10:53來源:今日頭條

什么是索引?

在關(guān)系數(shù)據(jù)庫(kù)中,索引是一種單獨(dú)的、物理的對(duì)數(shù)據(jù)庫(kù)表中一列或多列的值進(jìn)行排序的一種存儲(chǔ)結(jié)構(gòu),它是某個(gè)表中一列或若干列值的集合和相應(yīng)的指向表中物理標(biāo)識(shí)這些值的數(shù)據(jù)頁(yè)的邏輯指針清單。索引的作用相當(dāng)于圖書的目錄,可以根據(jù)目錄中的頁(yè)碼快速找到所需的內(nèi)容。

能實(shí)現(xiàn)快速定位數(shù)據(jù)的一種存儲(chǔ)結(jié)構(gòu),其設(shè)計(jì)思想是以空間換時(shí)間。


【資料圖】

索引的分類

按「數(shù)據(jù)結(jié)構(gòu)」分類:B+tree索引、Hash索引、Full-text索引。按「物理存儲(chǔ)」分類:聚簇索引(主鍵索引)、二級(jí)索引(輔助索引)。按「字段特性」分類:主鍵索引、唯一索引、普通索引、前綴索引。按「字段個(gè)數(shù)」分類:?jiǎn)瘟兴饕?、?lián)合索引。

MySQL如何實(shí)現(xiàn)的索引機(jī)制

這個(gè)話題比較大,在MySQL中有不同的存儲(chǔ)引擎比如像InnoDB MyISAM Memory 等等,每一種存儲(chǔ)引擎在其內(nèi)部實(shí)現(xiàn)索引機(jī)制的原理也有所不同。在MySQL5.5之后默認(rèn)的就是InnoDB,并且是目前使用最廣泛的MySQL數(shù)據(jù)引擎,那我們就以InnoDB為例展開講講。

?如果說我們?cè)诒碇杏?00條數(shù)據(jù),而我們要找出我們需要的數(shù)據(jù),有哪些辦法?

? 我們是不是可以按照一種順序的方式一條一條往下去搜索,直到匹配到我們需要的數(shù)據(jù),這是一種方案在時(shí)間復(fù)雜度上是O(N),雖說效率差但也能用。? 二分查找法也是一種常用的比較高效的查詢算法,它的搜索效率為O(log(N)),雖說查找效率是比順序查找高了不少,但是它有兩個(gè)前提條件,必須用順序存儲(chǔ)結(jié)構(gòu)比如數(shù)組,第二個(gè)是必須按照關(guān)鍵字進(jìn)行有序排序(從小到大)。? 哈希查找,哈希查找的特性是能夠做到直接定址,其效率無限接近于O(1),取決于沖突的數(shù)量。但是散列表數(shù)據(jù)是無序存儲(chǔ)的,排序要自己做,第二個(gè)是散列表還要擴(kuò)容耗時(shí)長(zhǎng),遇到散列沖突性能不穩(wěn)定。? B樹/B+樹查找的復(fù)雜度是O(log2(N)), 那么這也是InnoDB采用的數(shù)據(jù)結(jié)構(gòu),在查找效率上的非常高的,算法具體的原理在后面介紹。為什么InnoDB要使用B+樹作為索引結(jié)構(gòu)?InnoDB的索引和MyISAM的索引有什么區(qū)別?

首先InnoDB和MyISAM都是使用的B+樹實(shí)現(xiàn)的,但是InnoDB使用的是聚簇索引而MyISAM使用的是非聚簇索引,聚簇索引根據(jù)主鍵創(chuàng)建一顆B+樹,葉子節(jié)點(diǎn)則存放的是數(shù)據(jù)行記錄,也可以把葉子結(jié)點(diǎn)稱為數(shù)據(jù)頁(yè)。通俗點(diǎn)來說就是把數(shù)據(jù)和索引存在同一個(gè)塊,找到了索引也就找到了數(shù)據(jù)。

因?yàn)槿~子結(jié)點(diǎn)將索引和數(shù)據(jù)放在一起,就決定了聚簇索引的唯一性,一張表里面只能有一個(gè)聚簇索引。InnoDB引擎默認(rèn)將主鍵設(shè)置為聚簇索引,但如果沒有設(shè)置主鍵,那么InnoDB將會(huì)選擇非空的唯一索引作為代替,如果沒有這樣的索引,InnoDB將會(huì)定一個(gè)隱式主鍵作為聚簇索引。因?yàn)榫鄞厮饕厥獾奈锢斫Y(jié)構(gòu)所決定,葉子結(jié)點(diǎn)將索引和數(shù)據(jù)存放在一起,在獲取數(shù)據(jù)的速度上是比非聚簇索引快的。聚簇索引數(shù)據(jù)的存儲(chǔ)是有序的,在進(jìn)行排序查找和范圍查找的速度也是非??斓摹?? 也正因?yàn)橛行蛐?,在?shù)據(jù)插入時(shí)按照主鍵的順序插入是最快的,否則就會(huì)出現(xiàn)頁(yè)分裂等問題,嚴(yán)重影響性能。對(duì)于InnoDB我們一般采用自增作為主鍵ID。第二個(gè)問題主鍵最好不要進(jìn)行更新,修改主鍵的代價(jià)非常大,為了保持有序性會(huì)導(dǎo)致更新的行移動(dòng),一般來說我們通常設(shè)置為主鍵不可更新。

?在這部分只介紹InnoDB和MyISAM主鍵索引的不同?輔助索引后面在說

而非聚簇索引是將索引和數(shù)據(jù)分開存儲(chǔ),那么在訪問數(shù)據(jù)的時(shí)候就需要2次查找,但是和InnoDB的非聚簇部分還是有所區(qū)別。InnoDB是需要查找2次樹,先查找輔助索引樹,再查找聚簇索引樹(這個(gè)過程也叫回表)。而MyISAM的主鍵索引葉子結(jié)點(diǎn)的存儲(chǔ)的部分還是有所區(qū)別。InnoDB中存儲(chǔ)的是索引和聚簇索引ID,但是MyISAM中存儲(chǔ)的是索引和數(shù)據(jù)行的地址,只要定位就可以獲取到。

其實(shí)看到這個(gè)部分會(huì)有一個(gè)疑惑,那就是InnoDB的聚簇索引比MyISAM的主鍵快,那為什么會(huì)認(rèn)為MyISAM查詢效率比InnoDB快呢?

第一點(diǎn),對(duì)于兩者存儲(chǔ)引擎的的性能分析不能只看主鍵索引,我們也要看看輔助索引,前頭我們介紹過InnoDB輔助索引會(huì)存在一個(gè)回表的過程。而MyISAM的輔助索引和主鍵索引的原理是一樣的,并沒有什么區(qū)別。(重點(diǎn)) InnoDB對(duì)MVCC的支持,事物是比較影響性能的,就算你沒用但是也省不了檢查和維護(hù),而MyISAM這塊卻沒有這方面的影響,具體MVCC詳解將在后面章節(jié)描述。如果一個(gè)表沒有主鍵索引那還會(huì)創(chuàng)建B+樹嗎?

答案是會(huì)的!?。?/p>

InnoDB是MySQL中的一種存儲(chǔ)引擎,它會(huì)為每個(gè)表創(chuàng)建一個(gè)主鍵索引。如果表沒有明確的主鍵索引,InnoDB會(huì)使用一個(gè)隱藏的、自動(dòng)生成的主鍵來創(chuàng)建索引。這個(gè)隱藏的主鍵索引使用的就是B+樹結(jié)構(gòu)。因此,在InnoDB中,即使表沒有明確的主鍵索引,也會(huì)創(chuàng)建一個(gè)B+樹索引。

索引的優(yōu)缺點(diǎn)是什么?

數(shù)據(jù)是存儲(chǔ)在磁盤上的,操作系統(tǒng)讀取磁盤的最小單位是塊,如果沒有索引,會(huì)加載所有的數(shù)據(jù)到內(nèi)存,依次進(jìn)行檢索,加載的總數(shù)據(jù)會(huì)很多,磁盤IO多。

如果有了索引,會(huì)以學(xué)號(hào)為key創(chuàng)建索引,MySQL采用B+樹結(jié)構(gòu)存儲(chǔ),一方面加載的數(shù)據(jù)只有學(xué)號(hào)和主鍵ID,另一方便采用了多叉平衡樹,定位到指定學(xué)號(hào)會(huì)很快,根據(jù)關(guān)聯(lián)的ID可以快速定位到對(duì)應(yīng)行的數(shù)據(jù),所以檢索的速度會(huì)很快,因?yàn)榧虞d的總數(shù)據(jù)很少,磁盤IO少。

可見,索引可以大大減少檢索數(shù)據(jù)的范圍、減少磁盤IO,使查詢速度很快,因?yàn)榇疟PIO是很慢的,是由它的硬件結(jié)構(gòu)決定的。

? 優(yōu)點(diǎn)索引能夠提高數(shù)據(jù)檢索的效率,降低數(shù)據(jù)庫(kù)的IO成本。通過創(chuàng)建唯一性索引,可以保證數(shù)據(jù)庫(kù)表中每一行數(shù)據(jù)的唯一性,創(chuàng)建唯一索引在使用分組和排序子句進(jìn)行數(shù)據(jù)檢索時(shí),同樣可以顯著減少查詢中分組和排序的時(shí)間加速兩個(gè)表之間的連接,一般是在外鍵上創(chuàng)建索引? 缺點(diǎn)需要占用物理空間,建立的索引越多需要的空間越大創(chuàng)建索引和維護(hù)索引要耗費(fèi)時(shí)間,這種時(shí)間隨著數(shù)據(jù)量的增加而增加會(huì)降低表的增刪改的效率,因?yàn)槊看卧鰟h改索引需要進(jìn)行動(dòng)態(tài)維護(hù),導(dǎo)致時(shí)間變長(zhǎng)使用索引一定能提升效率嗎?(什么時(shí)候適合創(chuàng)建索引,什么時(shí)候不適合創(chuàng)建索引?)

答案是不一定,任何事物我們都應(yīng)該辯證的看,知道其運(yùn)行邏輯從而利用其優(yōu)點(diǎn),盡量避開它的缺點(diǎn)。在上面我們已經(jīng)和大家介紹了過了索引帶來的優(yōu)缺點(diǎn),那接下來就和大家分享幾個(gè)建索引的提示。

對(duì)于查詢中使用的少的字段盡量不要?jiǎng)?chuàng)建索引,創(chuàng)建索引是有成本的,空間占用、創(chuàng)建和維護(hù)成本、增刪改效率降低。對(duì)于數(shù)據(jù)密度小的列也不建議創(chuàng)建索引,因?yàn)镮nnoDB中索引的B+樹所決定的,你能帶來的效率提升非常有限。(但是也有例外,舉個(gè)例子枚舉值(1,2,3),頭兩個(gè)占比百分之1%,第三個(gè)占比99%,并且頭兩個(gè)搜索占比比第三個(gè)高很多,那么是可以建議加索引的)。InnoDB的輔助索引是存在回表的,如果數(shù)據(jù)密度過小,那么性能可能還不如全表掃。像上面這種場(chǎng)景具有特殊性,也說明一個(gè)道理,在大多數(shù)場(chǎng)景下建議可能適用,但是也有不適用的時(shí)候,我們不要把這種建議當(dāng)作鐵律。如何查看一個(gè)表的索引?

?? 上代碼 ??

show index from table_name (表名)
有哪些情況會(huì)導(dǎo)致索引失效?

這個(gè)問題要分版本回答!??!版本不同可能會(huì)導(dǎo)致索引失效的場(chǎng)景也不同,直接給答案的都是耍流氓!?。?/p>

這里回答基于最新MySQL8版本,MySQL8失效的以前版本也失效,MySQL8不失效的,以前可能會(huì)失效。

使用like并且是左邊帶%, 右邊可以帶會(huì)走索引(但是并不絕對(duì),詳細(xì)解釋看下面like專題分析)隱式類型轉(zhuǎn)換,索引字段與條件或關(guān)聯(lián)字段的類型不一致。(比如你的字段是int,你用字符串方式去查詢會(huì)導(dǎo)致索引失效)。在where條件里面對(duì)索引列使用運(yùn)算或者使用函數(shù)。使用OR且存在非索引列在where條件中兩列做比較會(huì)導(dǎo)致索引失效使用IN可能不會(huì)走索引(MySQL環(huán)境變量eq_range_index_dive_limit的值對(duì)IN語(yǔ)法有很大影響,該參數(shù)表示使用索引情況下IN中參數(shù)的最大數(shù)量。MySQL 5.7.3以及之前的版本中,eq_range_index_dive_limit的默認(rèn)值為10,之后的版本默認(rèn)值為200。我們拿MySQL8.0.19舉例,eq_range_index_dive_limit=200表示當(dāng)IN (...)中的值 >200個(gè)時(shí),該查詢一定不會(huì)走索引。<=200則可能用到索引。)使用非主鍵范圍條件查詢時(shí),部分情況索引失效。使用order by可能會(huì)導(dǎo)致索引失效is null is not null ≠ 可能會(huì)導(dǎo)致索引失效如果表中有字段為NULL 索引是否會(huì)失效?

首先講答案不一定。即使我們使用is null 或者is not null 它其實(shí)都是會(huì)走索引的。那為什么會(huì)有這樣的言論呢?這里首先就得來講講NULL值是怎么在記錄中存儲(chǔ)的,又是怎么在B+樹中存儲(chǔ)的呢。

那么在InnoDB中分為聚簇索引和非聚簇索引兩種,聚簇索引本身是不允許記錄為空的,所以可以不不用考慮,那么就剩下非聚簇索引也就是我們的輔助索引。

那既然IS NULL、IS NOT NULL、!=這些條件都可能使用到索引,那到底什么時(shí)候索引,什么時(shí)候采用全表掃描呢?

首先我們得知道兩個(gè)東西,第一個(gè)在InnoDB引擎是如何存儲(chǔ)NULL值的,第二個(gè)問題是索引是如何存儲(chǔ)NULL值的,這樣我們才能從根上理解NULL在什么場(chǎng)景走索引,在什么場(chǎng)景不走索引。

1??在InnoDB引擎是如何存儲(chǔ)NULL值的?

InnoDB引擎通過使用一個(gè)特殊的值來表示null,這個(gè)值通常被稱為"null bitmap"。null bitmap是一個(gè)二進(jìn)制位序列,用來標(biāo)記表中每一個(gè)列是否為null。當(dāng)null bitmap中對(duì)應(yīng)的位為1時(shí),表示對(duì)應(yīng)的列為null;當(dāng)null bitmap中對(duì)應(yīng)的位為0時(shí),表示對(duì)應(yīng)的列不為null。在實(shí)際存儲(chǔ)時(shí),InnoDB引擎會(huì)將null bitmap作為行記錄的一部分,存儲(chǔ)在行記錄的開頭,這樣可以在讀取行記錄時(shí)快速判斷每個(gè)列是否為null。

從頭開始說理解起來會(huì)比較容易,理解了獨(dú)占表空間文件就更容易理解行格式了,接著往下看:

當(dāng)我們創(chuàng)建表的時(shí)候默認(rèn)會(huì)創(chuàng)建一個(gè)*.idb 文件,這個(gè)文件又稱為獨(dú)占表空間文件,它是由段、區(qū)、頁(yè)、行組成。InnoDB存儲(chǔ)引擎獨(dú)占表空間大致如下圖;

Segment(表空間) 是由各個(gè)段(segment)組成的,段是由多個(gè)區(qū)(extent)組成的。段一般分為數(shù)據(jù)段、索引段和回滾段等。

數(shù)據(jù)段存放 B + 樹的葉子節(jié)點(diǎn)的區(qū)的集合索引段存放 B + 樹的非葉子節(jié)點(diǎn)的區(qū)的集合回滾段存放的是回滾數(shù)據(jù)的區(qū)的集合, MVCC就是利用了回滾段實(shí)現(xiàn)了多版本查詢數(shù)據(jù)

Extent(區(qū))在表中數(shù)據(jù)量大的時(shí)候,為某個(gè)索引分配空間的時(shí)候就不再按照頁(yè)為單位分配了,而是按照區(qū)(extent)為單位分配。每個(gè)區(qū)的大小為 1MB,對(duì)于 16KB 的頁(yè)來說,連續(xù)的 64 個(gè)頁(yè)會(huì)被劃為一個(gè)區(qū),這樣就使得鏈表中相鄰的頁(yè)的物理位置也相鄰,就能使用順序 I/O 了 。

(我們知道 InnoDB 存儲(chǔ)引擎是用 B+ 樹來組織數(shù)據(jù)的。B+ 樹中每一層都是通過雙向鏈表連接起來的,如果是以頁(yè)為單位來分配存儲(chǔ)空間,那么鏈表中相鄰的兩個(gè)頁(yè)之間的物理位置并不是連續(xù)的,可能離得非常遠(yuǎn),那么磁盤查詢時(shí)就會(huì)有大量的隨機(jī)I/O,隨機(jī) I/O 是非常慢的。解決這個(gè)問題也很簡(jiǎn)單,就是讓鏈表中相鄰的頁(yè)的物理位置也相鄰,這樣就可以使用順序 I/O 了,那么在范圍查詢(掃描葉子節(jié)點(diǎn))的時(shí)候性能就會(huì)很高。)

Page(頁(yè))記錄是按照行來存儲(chǔ)的,但是數(shù)據(jù)庫(kù)的讀取并不以「行」為單位,否則一次讀?。ㄒ簿褪且淮?I/O 操作)只能處理一行數(shù)據(jù),效率會(huì)非常低。

因此,InnoDB 的數(shù)據(jù)是按「頁(yè)」為單位來讀寫的,也就是說,當(dāng)需要讀一條記錄的時(shí)候,并不是將這個(gè)行記錄從磁盤讀出來,而是以頁(yè)為單位,將其整體讀入內(nèi)存。

默認(rèn)每個(gè)頁(yè)的大小為 16KB,也就是最多能保證 16KB 的連續(xù)存儲(chǔ)空間。

頁(yè)是 InnoDB 存儲(chǔ)引擎磁盤管理的最小單元,意味著數(shù)據(jù)庫(kù)每次讀寫都是以 16KB 為單位的,一次最少?gòu)拇疟P中讀取 16K 的內(nèi)容到內(nèi)存中,一次最少把內(nèi)存中的 16K 內(nèi)容刷新到磁盤中。

頁(yè)的類型有很多,常見的有數(shù)據(jù)頁(yè)、undo 日志頁(yè)、溢出頁(yè)等等。數(shù)據(jù)表中的行記錄是用「數(shù)據(jù)頁(yè)」來管理的,數(shù)據(jù)頁(yè)的結(jié)構(gòu)這里我就不講細(xì)說了,總之知道表中的記錄存儲(chǔ)在「數(shù)據(jù)頁(yè)」里面就行。

Row(行)數(shù)據(jù)庫(kù)表中的記錄都是按行(row)進(jìn)行存放的,每行記錄根據(jù)不同的行格式,有不同的存儲(chǔ)結(jié)構(gòu)。

重點(diǎn)來了?。?!

InnoDB 提供了 4 種行格式,分別是 Redundant、Compact、Dynamic和 Compressed 行格式。

Redundant是很古老的行格式了, MySQL 5.0 版本之前用的行格式,現(xiàn)在基本沒人用了,那就不展開詳講了。MySQL 5.0 之后引入了Compact行記錄存儲(chǔ)方式,由于 Redundant 不是一種緊湊的行格式,而采用更為緊湊的Compact ,設(shè)計(jì)的初衷就是為了讓一個(gè)數(shù)據(jù)頁(yè)中可以存放更多的行記錄,從 MySQL 5.1 版本之后,行格式默認(rèn)設(shè)置成 Compact。Dynamic和Compressed兩個(gè)都是緊湊的行格式,它們的行格式都和 Compact 差不多,因?yàn)槎际腔贑ompact改進(jìn)一點(diǎn)東西。從 MySQL5.7 版本之后,默認(rèn)使用Dynamic行格式。

那么我們來看看Compact里面長(zhǎng)什么樣,先混個(gè)臉熟。

這里簡(jiǎn)單介紹一下,Compact行格式其他內(nèi)容后面單獨(dú)出一個(gè)章節(jié)介紹。

NULL值列表(本問題介紹重點(diǎn))表中的某些列可能會(huì)存儲(chǔ) NULL 值,如果把這些 NULL 值都放到記錄的真實(shí)數(shù)據(jù)中會(huì)比較浪費(fèi)空間,所以 Compact 行格式把這些值為 NULL 的列存儲(chǔ)到 NULL值列表中。如果存在允許 NULL 值的列,則每個(gè)列對(duì)應(yīng)一個(gè)二進(jìn)制位(bit),二進(jìn)制位按照列的順序逆序排列。二進(jìn)制位的值為1時(shí),代表該列的值為NULL。二進(jìn)制位的值為0時(shí),代表該列的值不為NULL。另外,NULL 值列表必須用整數(shù)個(gè)字節(jié)的位表示(1字節(jié)8位),如果使用的二進(jìn)制位個(gè)數(shù)不足整數(shù)個(gè)字節(jié),則在字節(jié)的高位補(bǔ) 0。當(dāng)然NULL 值列表也不是必須的。當(dāng)數(shù)據(jù)表的字段都定義成 NOT NULL 的時(shí)候,這時(shí)候表里的行格式就不會(huì)有 NULL 值列表了。所以在設(shè)計(jì)數(shù)據(jù)庫(kù)表的時(shí)候,通常都是建議將字段設(shè)置為 NOT NULL,這樣可以節(jié)省 1 字節(jié)的空間(NULL 值列表占用 1 字節(jié)空間)?!窷ULL 值列表」的空間不是固定 1 字節(jié)的。當(dāng)一條記錄有 9 個(gè)字段值都是 NULL,那么就會(huì)創(chuàng)建 2 字節(jié)空間的「NULL 值列表」,以此類推。

2??索引是如何存儲(chǔ)NULL值的?

我們知道InnoDB引擎中按照物理存儲(chǔ)的不同分為聚簇索引和非聚簇索引,聚簇索引也就是主鍵索引,那么是不允許為空的。那就不再我們本問題的討論范圍,我們重點(diǎn)來看看非聚簇索引,非聚簇索引是允許值為空的。

在InnoDB中非聚簇索引是通過B+樹的方式進(jìn)行存儲(chǔ)的

從圖中可以看出,對(duì)于s1表的二級(jí)索引idx_key1來說,值為NULL的二級(jí)索引記錄都被放在了B+樹的最左邊,這是因?yàn)樵O(shè)計(jì)InnoDB的大叔有這樣的規(guī)定:

We define the SQL null to be the smallest possible value of a field.

也就是說他們把SQL中的NULL值認(rèn)為是列中最小的值。在通過二級(jí)索引idx_key1對(duì)應(yīng)的B+樹快速定位到葉子節(jié)點(diǎn)中符合條件的最左邊的那條記錄后,也就是本例中id值為521的那條記錄之后,就可以順著每條記錄都有的next_record屬性沿著由記錄組成的單向鏈表去獲取記錄了,直到某條記錄的key1列不為NULL。

3??我們了解了上面的兩個(gè)問題之后,我們就可以來看看,使不使用索引的依據(jù)是什么了

實(shí)際上來說我們用is null is not null ≠ 這些條件都是能走索引的,那什么時(shí)候走索引什么時(shí)候走全表掃描呢?

總結(jié)起來就是兩個(gè)字:成本?。。?/p>

如何去度量成本計(jì)算使用某個(gè)索引執(zhí)行查詢的成本就非常復(fù)雜了,展開講這個(gè)話題就停不下來了,后面考慮單獨(dú)列一個(gè)篇幅去講。

這里總結(jié)性講講:第一個(gè),讀取二級(jí)索引記錄的成本,第二,將二級(jí)索引記錄執(zhí)行回表操作,也就是到聚簇索引中找到完整的用戶記錄操作所付出的成本。

要掃描的二級(jí)索引記錄條數(shù)越多,那么需要執(zhí)行的回表操作的次數(shù)也就越多,達(dá)到了某個(gè)比例時(shí),使用二級(jí)索引執(zhí)行查詢的成本也就超過了全表掃描的成本(舉一個(gè)極端的例子,比方說要掃描的全部的二級(jí)索引記錄,那就要對(duì)每條記錄執(zhí)行一遍回表操作,自然不如直接掃描聚簇索引來的快)

所以MySQL優(yōu)化器在真正執(zhí)行查詢之前,對(duì)于每個(gè)可能使用到的索引來說,都會(huì)預(yù)先計(jì)算一下需要掃描的二級(jí)索引記錄的數(shù)量,比方說對(duì)于下邊這個(gè)查詢:

SELECT * FROM s1 WHERE key1 IS NULL;

優(yōu)化器會(huì)分析出此查詢只需要查找key1值為NULL的記錄,然后訪問一下二級(jí)索引idx_key1,看一下值為NULL的記錄有多少(如果符合條件的二級(jí)索引記錄數(shù)量較少,那么統(tǒng)計(jì)結(jié)果是精確的,如果太多的話,會(huì)采用一定的手段計(jì)算一個(gè)模糊的值,當(dāng)然算法也比較麻煩,我們就不展開說了),這種在查詢真正執(zhí)行前優(yōu)化器就率先訪問索引來計(jì)算需要掃描的索引記錄數(shù)量的方式稱之為index dive。當(dāng)然,對(duì)于某些查詢,比方說WHERE子句中有IN條件,并且IN條件中包含許多參數(shù)的話,比方說這樣:

SELECT * FROM s1 WHERE key1 IN ("a", "b", "c", ... , "zzzzzzz");

這樣的話需要統(tǒng)計(jì)的key1值所在的區(qū)間就太多了,這樣就不能采用index dive的方式去真正的訪問二級(jí)索引idx_key1,而是需要采用之前在背地里產(chǎn)生的一些統(tǒng)計(jì)數(shù)據(jù)去估算匹配的二級(jí)索引記錄有多少條(很顯然根據(jù)統(tǒng)計(jì)數(shù)據(jù)去估算記錄條數(shù)比index dive的方式精確性差了很多)。

反正不論采用index dive還是依據(jù)統(tǒng)計(jì)數(shù)據(jù)估算,最終要得到一個(gè)需要掃描的二級(jí)索引記錄條數(shù),如果這個(gè)條數(shù)占整個(gè)記錄條數(shù)的比例特別大,那么就趨向于使用全表掃描執(zhí)行查詢,否則趨向于使用這個(gè)索引執(zhí)行查詢。

理解了這個(gè)也就好理解為什么在WHERE子句中出現(xiàn)IS NULL、IS NOT NULL、!=這些條件仍然可以使用索引,本質(zhì)上都是優(yōu)化器去計(jì)算一下對(duì)應(yīng)的二級(jí)索引數(shù)量占所有記錄數(shù)量的比值而已。

大家可以看到,MySQL中決定使不使用某個(gè)索引執(zhí)行查詢的依據(jù)很簡(jiǎn)單:就是成本夠不夠小。而不是是否在WHERE子句中用了IS NULL、IS NOT NULL、!=這些條件。大家以后也多多辟謠吧,沒那么復(fù)雜,只是一個(gè)成本而已。

為什么LIKE以%開頭索引會(huì)失效?

首先看看B+樹是如何查找數(shù)據(jù)的:

查找數(shù)據(jù)時(shí),MySQL會(huì)從根節(jié)點(diǎn)開始,按照從左到右的順序比較查詢條件和節(jié)點(diǎn)中的鍵值。如果查詢條件小于節(jié)點(diǎn)中的鍵值,則跳到該節(jié)點(diǎn)的左子節(jié)點(diǎn)繼續(xù)查找;如果查詢條件大于節(jié)點(diǎn)中的鍵值,則跳到該節(jié)點(diǎn)的右子節(jié)點(diǎn)繼續(xù)查找;如果查詢條件等于節(jié)點(diǎn)中的鍵值,則繼續(xù)查找該節(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)。

比如說我有下面這條SQL:

select * from `user` where nickname like "%冥";

如果數(shù)據(jù)庫(kù)中存在南冥 北冥 西冥 東冥 ,那么在B+樹中搜索的效率和全表掃描還有什么區(qū)別呢?

我走聚簇索引全表掃描還不用回表。

最后在擴(kuò)展講一個(gè)點(diǎn),其實(shí)不一定會(huì)導(dǎo)致索引失效。舉個(gè)例子:

create table `user`(  id int primary key auto_increment,  name varchar(20),  index idx_name(name),);// 那么這種情況是會(huì)走索引的。select id,name from `user` where name like "%冥";

為什么說上面的例子會(huì)走索引呢?

首先我們需要查詢的id name 這兩個(gè)字段是不是都在我們的輔助索引中,葉子節(jié)點(diǎn)是不是存的索引值和主鍵值,所以我們只要查輔助索引就可以直接拿到我們的需要的結(jié)果了,那么這個(gè)叫做索引覆蓋。我們觀察執(zhí)行計(jì)劃會(huì)發(fā)現(xiàn)它的查詢級(jí)別是index ,其實(shí)也是全表遍歷了輔助索引。

第二個(gè)問題來了,那為什么就要走輔助索引而不是走全表掃描呢?

因?yàn)檩o助索引中記錄的東西比主鍵索引少了很多,只有索引值和主鍵值,但是主鍵索引中就包含了,其他值、事物ID、MVCC的回流指針等等。再加上索引覆蓋不用回表,優(yōu)化器就認(rèn)為直接遍歷輔助索引的效率高于主鍵索引。

什么是索引覆蓋?

索引覆蓋(Index Covering)是指通過在索引中包含所有查詢語(yǔ)句中所需的列,可以避免對(duì)表中的數(shù)據(jù)進(jìn)行額外的訪問,從而提高查詢效率。(避免了回表操作)

例如,對(duì)于一個(gè)查詢語(yǔ)句:

SELECT col1, col2, col3 FROM table WHERE col1 = x AND col2 = y

如果在table表中建立了一個(gè)索引,包含col1、col2和col3三列,那么MySQL可以通過索引定位到符合條件的數(shù)據(jù),并在索引中提取col1、col2和col3列的值,無需對(duì)表中的數(shù)據(jù)進(jìn)行額外的訪問。這種方式就叫做索引覆蓋。

索引覆蓋能夠顯著提高查詢效率,因此在建立索引時(shí)應(yīng)盡量考慮包含查詢語(yǔ)句中所需的所有列。

什么是聚簇索引?

聚簇索引是一種特殊的索引,它將數(shù)據(jù)存儲(chǔ)在索引樹的葉子節(jié)點(diǎn)上。這種索引方式的優(yōu)點(diǎn)是,在查詢數(shù)據(jù)時(shí)可以減少一次查詢,因?yàn)椴樵兯饕龢涞耐瑫r(shí)就能獲取到數(shù)據(jù)。聚簇索引的缺點(diǎn)是,因?yàn)閿?shù)據(jù)存儲(chǔ)在索引樹中,所以對(duì)數(shù)據(jù)進(jìn)行修改或刪除操作時(shí)需要更新索引樹,這會(huì)增加系統(tǒng)的開銷。

聚簇索引與非聚集索引的特點(diǎn)是什么?

在InnoDB中聚簇索引和非聚簇索引實(shí)際上是物理空間存儲(chǔ)方式的一個(gè)不同。

聚簇索引聚簇索引將數(shù)據(jù)存儲(chǔ)在索引樹的葉子節(jié)點(diǎn)上。聚簇索引可以減少一次查詢,因?yàn)椴樵兯饕龢涞耐瑫r(shí)就能獲取到數(shù)據(jù)。聚簇索引的缺點(diǎn)是,對(duì)數(shù)據(jù)進(jìn)行修改或刪除操作時(shí)需要更新索引樹,會(huì)增加系統(tǒng)的開銷。聚簇索引通常用于數(shù)據(jù)庫(kù)系統(tǒng)中,主要用于提高查詢效率。非聚簇索引(又稱二級(jí)索引 / 輔助索引)非聚簇索引不將數(shù)據(jù)存儲(chǔ)在索引樹的葉子節(jié)點(diǎn)上,而是存儲(chǔ)在數(shù)據(jù)頁(yè)中。非聚簇索引在查詢數(shù)據(jù)時(shí)需要兩次查詢,一次查詢索引樹,獲取數(shù)據(jù)頁(yè)的地址,再通過數(shù)據(jù)頁(yè)的地址查詢數(shù)據(jù)(通常情況下來說是的,但如果索引覆蓋的話實(shí)際上是不用回表的)。非聚簇索引的優(yōu)點(diǎn)是,對(duì)數(shù)據(jù)進(jìn)行修改或刪除操作時(shí)不需要更新索引樹,減少了系統(tǒng)的開銷。非聚簇索引通常用于數(shù)據(jù)庫(kù)系統(tǒng)中,主要用于提高數(shù)據(jù)更新和刪除操作的效率。聚簇索引與非聚簇索引b+樹實(shí)現(xiàn)有什么區(qū)別?

結(jié)合“聚簇索引與非聚集索引的特點(diǎn)是什么?”加上下圖就明白了

一個(gè)表中可以有多個(gè)(非)聚簇索引嗎?

可以,這題容易混淆聚簇和非聚簇,聚簇只能有一個(gè),但是非聚簇可以有很多,因?yàn)榫鄞厥呛蛿?shù)據(jù)存放在一起的,但是非聚簇是單獨(dú)的。(同時(shí)這題可以結(jié)合上面兩個(gè)問題回答)

非聚簇索引為什么不存數(shù)據(jù)地址值而存儲(chǔ)主鍵?

我們知道在MyISAM引擎中是沒有聚簇索引,都是存的輔助索引。但是和InnoDB不同的是存儲(chǔ)的,它是存儲(chǔ)索引值和數(shù)據(jù)地址,而我們InnoDB中存儲(chǔ)的是主鍵ID。

我們要記住知道一個(gè)點(diǎn),數(shù)據(jù)是會(huì)不斷變動(dòng)的,那么它的一個(gè)地址也是會(huì)跟著不斷變動(dòng),如果直接存儲(chǔ)地址,下次找到的數(shù)據(jù)可能就不是原來的數(shù)據(jù)了。如果要解決這個(gè)問題的話,成本是非常高的。每次數(shù)據(jù)變動(dòng)都需要進(jìn)行調(diào)整。

一個(gè)b+樹中大概能存放多少條索引記錄?什么是Hash索引?

哈希索引(hash index)基于哈希表實(shí)現(xiàn)。哈希索引通過Hash算法將數(shù)據(jù)庫(kù)的索引列數(shù)據(jù)轉(zhuǎn)換成定長(zhǎng)的哈希碼作為key,將這條數(shù)據(jù)的行的地址作為value一并存入Hash表的對(duì)應(yīng)位置。

在MySQL中,只有Memeory引擎顯式的支持哈希索引,這也是Memory引擎表的默認(rèn)索引結(jié)構(gòu),Memeory同時(shí)也支持B-Tree索引。并且,Memory引擎支持非唯一哈希索引,如果多個(gè)列的哈希值相同(或者發(fā)生了Hash碰撞),索引會(huì)在對(duì)應(yīng)Hash鍵下以鏈表形式存儲(chǔ)多個(gè)記錄地址。

哈希索引還有如下特點(diǎn):

哈希索引不支持部分索引列的匹配查找,因?yàn)楣K饕冀K是使用索引列的全部?jī)?nèi)容來計(jì)算哈希值的。例如,在數(shù)據(jù)列(A,B)上建立哈希索引,如果查詢只有數(shù)據(jù)列A,則無法使用該索引。哈希索引具有哈希表的特性,因此只有精確匹配所有列的查詢對(duì)于哈希索引才有效,比如=、<>、IN(,因?yàn)閿?shù)據(jù)的存儲(chǔ)是無序的),且無法使用任何范圍查詢。因?yàn)閿?shù)據(jù)的存儲(chǔ)是無序的,哈希索引還無法用于排序。對(duì)于精確查詢,則哈希索引效率很高,時(shí)間復(fù)雜度為O(1),除非有很多哈希沖突(不同的索引列有相同的哈希值),如果發(fā)生哈希沖突,則存儲(chǔ)引擎必須遍歷鏈表中的所有數(shù)據(jù)指針,逐行比較,直到找到所有符合條件的行。哈希沖突越多,代價(jià)就越大!InnoDB到底支不支持哈希索引?

對(duì)于InnoDB的哈希索引,確切的應(yīng)該這么說:

InnoDB用戶無法手動(dòng)創(chuàng)建哈希索引,這一層上說,InnoDB確實(shí)不支持哈希索引;InnoDB會(huì)自調(diào)優(yōu)(self-tuning),如果判定建立自適應(yīng)哈希索引(Adaptive Hash Index, AHI),能夠提升查詢效率,InnoDB自己會(huì)建立相關(guān)哈希索引,這一層上說,InnoDB又是支持哈希索引的;

那什么是自適應(yīng)哈希索引(Adaptive Hash Index, AHI)呢?

1、自適應(yīng)即我們不需要自己處理,當(dāng)InnoDB引擎根據(jù)查詢統(tǒng)計(jì)發(fā)現(xiàn)某一查詢滿足hash索引的數(shù)據(jù)結(jié)構(gòu)特點(diǎn),就會(huì)給其建立一個(gè)hash索引;

2、hash索引底層的數(shù)據(jù)結(jié)構(gòu)是散列表(Hash表),其數(shù)據(jù)特點(diǎn)就是比較適合在內(nèi)存中使用,自適應(yīng)Hash索引存在于InnoDB架構(gòu)中的緩存中(不存在于磁盤架構(gòu)中).

什么是索引下推?

索引下推(INDEX CONDITION PUSHDOWN,簡(jiǎn)稱 ICP)是在 MySQL 5.6 針對(duì)掃描二級(jí)索引的一項(xiàng)優(yōu)化改進(jìn)??偟膩碚f是通過把索引過濾條件下推到存儲(chǔ)引擎,來減少 MySQL 存儲(chǔ)引擎訪問基表的次數(shù)以及 MySQL 服務(wù)層訪問存儲(chǔ)引擎的次數(shù)。ICP 適用于 MYISAM 和 INNODB,本篇的內(nèi)容只基于 INNODB。

在講這個(gè)技術(shù)之前你得對(duì)mysql架構(gòu)有一個(gè)簡(jiǎn)單的認(rèn)識(shí),見下圖

MySQL 服務(wù)層:也就是 SERVER 層,用來解析 SQL 的語(yǔ)法、語(yǔ)義、生成查詢計(jì)劃、接管從 MySQL 存儲(chǔ)引擎層上推的數(shù)據(jù)進(jìn)行二次過濾等等。MySQL 存儲(chǔ)引擎層:按照 MySQL 服務(wù)層下發(fā)的請(qǐng)求,通過索引或者全表掃描等方式把數(shù)據(jù)上傳到 MySQL 服務(wù)層。MySQL 索引掃描:根據(jù)指定索引過濾條件,遍歷索引找到索引鍵對(duì)應(yīng)的主鍵值后回表過濾剩余過濾條件。MySQL 索引過濾:通過索引掃描并且基于索引進(jìn)行二次條件過濾后再回表。使用索引下推實(shí)現(xiàn)索引下推的使用條件ICP目標(biāo)是減少全行記錄讀取,從而減少IO 操作,只能用于非聚簇索引。聚簇索引本身包含的表數(shù)據(jù),也就不存在下推一說。只能用于range、 ref、 eq_ref、ref_or_null訪問方法;where 條件中是用 and 而非 or 的時(shí)候。ICP適用于分區(qū)表。ICP不支持基于虛擬列上建立的索引,比如說函數(shù)索引ICP不支持引用子查詢作為條件。ICP不支持存儲(chǔ)函數(shù)作為條件,因?yàn)榇鎯?chǔ)引擎無法調(diào)用存儲(chǔ)函數(shù)。

索引下推相關(guān)語(yǔ)句

# 查看索引下推是否開啟select @@optimizer_switch# 開啟索引下推set optimizer_switch="index_condition_pushdown=on";# 關(guān)閉索引下推set optimizer_switch="index_condition_pushdown=off";
什么是唯一索引?

講起來非常簡(jiǎn)單,其實(shí)和"普通索引"類似,不同的就是:索引列的值必須唯一,但允許有空值。可以是單列唯一索引,也可以是聯(lián)合唯一索引。

最大的所用就是確保寫入數(shù)據(jù)庫(kù)的數(shù)據(jù)是唯一值。什么時(shí)候應(yīng)該使用唯一索引呢?

我們前面講了唯一索引最大的好處就是能保證唯一性??此茮]什么太大的價(jià)值,可能就會(huì)有同學(xué)說,我業(yè)務(wù)層做一個(gè)重復(fù)檢查不就好了。問題就在這個(gè)地方,“業(yè)務(wù)是無法確保唯一性的”,除非你說你的代碼沒有BUG。很多時(shí)候業(yè)務(wù)場(chǎng)景需要保證唯一性,如果不在數(shù)據(jù)庫(kù)加限制的話,總有一天會(huì)出現(xiàn)臟數(shù)據(jù)。

那又有同學(xué)就說了,既然你不想重復(fù)你可以使用主鍵索引。這個(gè)回答也很有意思。

我們確實(shí)可以通過主鍵索引來保證唯一,但是,如果你的數(shù)據(jù)不能保證有序插入。比如說身份證字段,你如果用身份證字段作為主鍵的話,會(huì)導(dǎo)致查詢效率降低。唯一索引還有一個(gè)好處就是可以為空,真實(shí)的業(yè)務(wù)場(chǎng)景肯定是可以保證身份證為空的,如果沒有綁定身份證就不讓注冊(cè)好像也有點(diǎn)說不過去。

聚簇索引的原理就不在這里細(xì)講了,會(huì)有一個(gè)單獨(dú)的章節(jié)來介紹。

唯一索引是否會(huì)影響性能呢?

我們通過和普通索引來做一個(gè)對(duì)比,有查詢和插入兩個(gè)場(chǎng)景。

首先第一個(gè)數(shù)據(jù)查詢,一般情況下來說索引是通過B+樹從根節(jié)點(diǎn)開始層序遍歷到葉子結(jié)點(diǎn),數(shù)據(jù)頁(yè)內(nèi)部通過二分搜索。

普通索引查到滿足條件的第一條記錄,繼續(xù)查找下一條記錄,直到找到不滿足條件的記錄唯一索引查到第一個(gè)滿足條件的記錄,就停止搜索。

InnoDB 它是以數(shù)據(jù)頁(yè)為單位進(jìn)行讀寫的,我們讀一條記錄,并不是從磁盤加載一條記錄,而是以頁(yè)為單位整體讀到內(nèi)存里面來的。

普通索引比唯一索引就多了一次查找和判斷下一條記錄的操作,也就是一次指針尋找數(shù)據(jù)和一次計(jì)算。當(dāng)然還有一種特殊情況,讀取到的這條數(shù)據(jù)正好是數(shù)據(jù)頁(yè)的最后一條,但是這種概率也是非常低,幾乎可以忽略不計(jì)。

整體看下來看上去性能差距并不大對(duì)吧。

來看第二個(gè)更新的性能,我們按照上面圖上的例子在2和6之間插入一個(gè)3。

在內(nèi)存中

普通索引找到2和6之間的位置 →插入值→ 結(jié)束唯一索引找到2和6之間的位置 →**當(dāng)判斷有沒有沖突**→ 插入值→ 結(jié)束

不在內(nèi)存中

普通索引將更新記錄在change buffer → 結(jié)束唯一索引將數(shù)據(jù)頁(yè)讀入內(nèi)存→當(dāng)判斷到?jīng)]有沖突→插入值→結(jié)束

數(shù)據(jù)讀取到內(nèi)存涉及了隨機(jī)IO訪問,這是在數(shù)據(jù)庫(kù)里面成本最高的操作之一,而change buffer 就可以減少這種隨機(jī)磁盤訪問,所以性能提示比較明顯。所以在這一塊來說,如果兩者在業(yè)務(wù)場(chǎng)景下都能滿足時(shí)可以優(yōu)先考慮使用普通索引。

什么是聯(lián)合索引,組合索引,復(fù)合索引?

我們?cè)谒饕仡櫟臅r(shí)候和大家對(duì)索引做了一個(gè)分類對(duì)吧,按照字段個(gè)數(shù)來分的話,就分為了單列索引和組合索引對(duì)吧。那么他們之間的特點(diǎn)是什么呢?我們來看

單列索引一個(gè)索引只包含了一個(gè)列,一個(gè)表里面可以有多個(gè)單列索引,但是這不叫組合索引。組合索引(聯(lián)合索引 & 復(fù)合索引)一個(gè)索引包含多個(gè)列。

看上去感覺這組合索引并沒有太大作用是吧,我一個(gè)列已經(jīng)有一個(gè)索引了,我還要這組合索引干嘛?

真相往往不那么簡(jiǎn)單,首先我們得承認(rèn)我們的業(yè)務(wù)千變?nèi)f化,我們的查詢語(yǔ)句條件肯定是非常多的。

高效率如果說只有單列索引,那就會(huì)涉及多次二級(jí)索引樹查找,再加上回表,性能相對(duì)于聯(lián)合索引來說是比較低的。減少開銷我們要記得創(chuàng)建索引是存在空間開銷的,對(duì)于大數(shù)據(jù)量的表,使用聯(lián)合索引會(huì)降低空間開銷。索引覆蓋如果組合索引索引值已經(jīng)滿足了我們的查詢條件,那么就不會(huì)進(jìn)行回表,直接返回。

但是我們按照我們的查詢條件去創(chuàng)建一個(gè)聯(lián)合索引的話,就避免了上面的問題。那么聯(lián)合索引是怎么工作的呢?

這里涉及到了一個(gè)重點(diǎn),叫做最左前綴,簡(jiǎn)單理解就是只會(huì)從最左邊開始組合,組合索引的第一個(gè)字段必須出現(xiàn)在查詢組句中,還不能跳躍,只有這樣才能讓索引生效,比如說我查詢條件里面有組合索引里面的第二個(gè)字段,那么也是不會(huì)走組合索引的。舉個(gè)例子

// 假設(shè)給username,age創(chuàng)建了組合索引// 這兩種情況是會(huì)走索引的select username,age from user where username = "張三" and age = 18;select * from user where username = "張三";// 這種是不會(huì)走索引的select * from user where age = 18;select * from user where city = "北京" and age = 18;
復(fù)合索引創(chuàng)建時(shí)字段順序不一樣使用效果一樣嗎?
// 特殊情況,這種也是會(huì)走索引的,雖然我的age在前面,username在后面。// 剛剛不是手最左前綴匹配嗎,為什么放到第二位也可以呢?// 雖說順序不一致,但是在SQL執(zhí)行過程中,根據(jù)查詢條件命中索引,// 無論我username在不在前面,都會(huì)按照username去進(jìn)行索引查找。select * from user where age = 18 and username = "張三";
使用Order By時(shí)能否通過索引排序?

我們知道在很多場(chǎng)景下會(huì)導(dǎo)致索引失效,比如說沒有遵循B+樹的最左匹配原則,但是也有一些情況是遵循了最左匹配原則但是還是沒有走索引,這里我們使用order by進(jìn)行排序的時(shí)候就有不走索引的情況,那么帶大家來分析一下

drop table if exists `user`;drop table if exists `user_example`;create table `user`(    `id` int primary key comment "主鍵ID",    `card_id` int comment "身份證",    `nickname` varchar(10) comment "昵稱",    `age` int not null comment "年齡",    key  `card_id` (`card_id`)) engine=InnoDB default charset=utf8mb4;// 這里我們明明對(duì)card_id建好了單列索引,那為什么不走索引呢?select * from `user` order by card_id
如果索引覆蓋是可以走索引的如果帶上索引條件是可以走索引的通過索引排序內(nèi)部流程是什么呢?
explain select nickname,card_id,age from user order by card_id;

我們?cè)诹私鈓ysql底層是怎么排序的之前,我們先來了解一下一個(gè)概念 sort buffer .

首先mysql會(huì)為每一個(gè)線程都分配一個(gè)固定大小的sort buffer 用于排序。它是一個(gè)具有邏輯概念的內(nèi)存區(qū)域,我們可以通過sort_buffer_size參數(shù)來控制,默認(rèn)值是256kb 。

// 輸入查看最,小可以設(shè)置為 32K,最大可以設(shè)置為 4G。show variables like "sort_buffer_size";

由于sort buffer 大小是一個(gè)固定的,但是我們待排序的數(shù)據(jù)量它不是,所以根據(jù)它們之間的一個(gè)差值呢,就分為了內(nèi)部排序和外部排序

當(dāng)待排序的數(shù)據(jù)量小于等于sort buffer 時(shí),那我們的sort buffer就能夠容納,MySQL就可以直接在內(nèi)存里面排序就行了,內(nèi)部排序使用的排序算法是快排當(dāng)待排序的數(shù)據(jù)量大于sort buffer 時(shí),那我們的sort buffer 就不夠用了對(duì)吧。這個(gè)時(shí)候MySQL就得要借助外部文件來進(jìn)行排序了。將待排序數(shù)據(jù)拆成多個(gè)小文件,對(duì)各個(gè)小文件進(jìn)行排序,最后再匯總成一個(gè)有序的文件,外部排序使用的算法時(shí)歸并排序我們來聊聊row_id排序

和大家說一個(gè)這個(gè)參數(shù)max_length_for_sort_data ,在我們MySQL中專門控制用戶排序的行數(shù)據(jù)長(zhǎng)度參數(shù)。默認(rèn)是4096,也就是說如果超過了這個(gè)長(zhǎng)度MySQL就會(huì)自動(dòng)升級(jí)成row_id算法。

// 默認(rèn)max_length_for_sort_data的大小為4096字節(jié)show variables like "max_length_for_sort_data";

row_id排序的思想就是把不需要的數(shù)據(jù)不放到sort_buffer中,讓sort_buffer中只存放需要排序的字段。

舉個(gè)例子:

explain select nickname,card_id,age from user order by card_id;

我們前面說到了sort buffer,在sort buffer里面進(jìn)行排序的數(shù)據(jù)是我們select的全部字段,所以當(dāng)我們查詢的字段越多,那么sort buffer能容納的數(shù)據(jù)量也就越小。而通過row_id排序就只會(huì)存放row_id 字段和排序相關(guān)的字段。其余的字段等排序完成之后通過主鍵ID進(jìn)行回表拿。

group by 分組和 order by 在索引使用上有什么不同嗎?

沒什么太大的差異group by實(shí)際是先進(jìn)行排序,再進(jìn)行分組。所以遵循order by的索引機(jī)制。

關(guān)鍵詞:

相關(guān)新聞

Copyright 2015-2020   三好網(wǎng)  版權(quán)所有 聯(lián)系郵箱:435 22 640@qq.com  備案號(hào): 京ICP備2022022245號(hào)-21
亚洲欧美国产一本综合首页| 中文字幕丰满子伦无码专区| 一区二区在线观看视频观看| 精品国模一区二区三区欧美| 亚洲宅男噜噜噜66在线观看| 久久99精品久久久久久三级| 三级欧美日韩一区二区三区| 五月婷婷伊人久久中文字幕| 天天综合久久无人区| 日韩人妻精品久久久久| 亚洲经典av中文字幕| 99久9在线视频播放| 黄片视频免费观看视频| 国产在线观看av一区| 日本少妇人妻中文在线| 超级黄肉动漫在线观看| 欧美精品999不卡| 亚洲欧美激情国产综合久久久| 中文字幕 首页 人妻| 99久9在线视频播放| 国语对白性爱三级片免费看| 五十岁熟妇高潮喷水| 69国产精品成人aaaaa片| 亚洲va999天堂va| 精品国产av虐杀两警花| 在线观看黄页网站视频网站| 中文字幕中文字幕在线中…一区| 69久久夜色精品国产69乱电影 | 国产午夜羞羞一区二区三区| 欧美精品一区二区三区观看| 亚洲色视频在线播放网站| 天天操天天干天天谢| 精品精品精品精品精品污污污污| 亚洲天堂色综合久久| 国产肥胖熟女又色又爽免费视频 | 欧美区日本区国产区| 欧美久久蜜臀蜜桃资源吧| 精品久久久久久久久久久久久| 一区二区三区国产在线成人av| 日本丰满熟妇浓密多毛| 黑川堇人妻88av| 午夜精品久久久久久久精品乱码| 亚洲欧美小说中文字幕| av中文字幕国产精品| 91九色尤物无套内射| 骚穴被阴茎插免费视频| 精品人妻 色中文熟女 oo| 女女抠逼白虎白丝袜| 午夜3p福利视频合集| 性高潮视频在线观看日韩| 在线人成视频免费观看尤物| 特级aaaaa黄色片| av在线中文字幕在线| 欧美成人区一区二区三| 国产女主播在线观看一区| 日本一区二区高清av中文| 午夜精品视频免费观看| 91九色人妻在线播放| 91青青青国产免费高清| 天堂av在线最新地址| 18在线观看免费观看| 自拍偷拍色图亚洲天堂| yy4080黄色片| 国产精品成人免费电影| 一区二区在线观看视频网站| 免费看日韩黄视频在线观看| 亚洲春色av中文字幕| 人妻少妇精品二三区| 国产,亚洲,欧美综合| 91九色国产在线视频| 午夜精品视频免费观看| 亚洲中文字幕无线乱码人妻精品| 亚洲美女色www色| 91超碰九色porny| 婷婷色综合五月天视频| 日韩欧美黄色免费网站| 2021国产在线视频| 国产精品蝌蚪自拍视频| 熟女人妻少妇一区二区| 亚洲人人爽人人澡起碰av| 2020国产成人精品视频| 河北全程露脸对白自拍| 夜夜爽夜夜操夜夜爱| 伊人精品成人综合网| 亚洲高清一区二区三区久久| 女人扒开逼让男人操| 黑川堇人妻88av| 91精品久久久久久久99蜜月| 色屁屁一区二区三区在线观看| 日本高清有码在线视频| 久久99精品久久久久久三级| 少妇熟女天堂网av| 欧美日韩福利视频网| 伊人精品久久一区二区| 一区二区在线观看视频网站| 天天日天天干天天日天天干天天| 亚洲a区在线免费观看| 91精品国产成人久久久久久| 91精产国品一二三产区区别网站 | 不用付费特黄特色亚洲特级黄色片| 成人资源中文在线观看| 国产农村乱子伦精精品视频| 68视频在线免费观看| 国产又粗又长又大视频| 亚洲成人,国产精品| 精品高潮呻吟久久av| 一区二区三区不卡免费视频网站| 伊人久久综合国产精品| 懂色av之国产精品| 天天色天天射天天日天天干| 免费高清av一区二区| 干逼又爽又黄又免费的视频| 狠狠操狠狠操狠狠插| 大陆中文字幕视频在线| 天天做天天日天天搞| 蜜乳av一区二区三区免费观看| 亚洲熟妇丰满多毛xxxx网站| 91精产国品一二三产区区别网站| 欧美日韩国产在线中文字幕| 亚洲精品1卡2卡3卡| 天天天天天天天天日日日| 中文字幕一区二区三区久久久| 亚洲国产精品 久久久| 天天操天天日天天碰| 国产精品内射婷婷一级| 九一精品人妻一区二区三区| 五月激情婷婷四射基地| xxnxx国产美女| xxoo福利视频导航| 亚洲第一页欧美第一页| 日本电影一级人妻在线播放四区 | 中文字幕人妻一区二区视频系列 | 黄版视频在线免费观看| 国产主播诱惑毛片av| 一区二区三区四区久久久久韩日| 一看就是假奶的av| 色哟哟亚洲乱码国产乱码精品精| 综合激情网,激情五月| 日本人妻熟妇丰满成熟HD系列| 97视频538在线观看| 中字幕人妻熟女人妻a62v网| 人人妻人人爽人人摸| 午夜情色一区二区三区| 日韩一区二区在线播放观看| 亚洲国产精品自拍偷拍视频在线| 日本欧美国产在线一区| 亚洲国产电影的一区| 国产人妻熟女ⅹxx丝袜| 狠狠操狠狠操狠狠插| 奇米网首页神马久久| 美女把逼扒开让男人桶| 51精品视频在线免费观看| 国产91精品福利系列| 在线免费观看a视频免费| 97香蕉久久国产超碰| 亚洲乱码av一区二区蜜桃av| 中出小骚货在线观看| 啊~插得好快别揉我胸了视频| 日本老熟妇av老熟妇| 川上优所有中文字幕在线| 久久一级片三上悠亚| 久久久国产精品免费视频网| 蜜乳视频一区二区三区| 亚洲无人区乱码中文字幕一区| 成人超碰一区二区三区| 美国男的操女孩的小嫩逼| 伊人情人成综合视频| 中文字幕人妻精品精品| 天天色天天射天天日天天干| 男女真人做带声音视频图片| 青青青青青爽视频在线| 快色视频在线观看免费| av男人站在线观看| 午夜精品久久久久久久精品乱码| 92在线播放观看视频| 亚洲成人自拍图片网站| 国产av高清二区三区| 欧美黑人1区2区3区| 亚洲全国精品女人久久久| 99女福利女女视频在线播放| 亚洲一区二区中文字幕久久| 国产激情在线观看一区二区三区| 人妻视频网站快射视频网站| 国产精品无码无卡免费观| 五月天男人的天堂中文字幕| jandara在线观看| 亚洲午夜熟女在线观看| 美女福利视频一区二区三区四区| 综合久久伊人久久88| 猫咪亚洲中文在线中文字幕| 一区二区九日韩美女| 91在线九色porny| 美女露阴道让男人捅| 综合久久伊人久久88| 精品国产污污污污免费观看| 日本少妇三级交换做爰做| 国产肥胖熟女又色又爽免费视频| av天堂a亚洲va天堂va里番| 自拍偷拍视频亚洲一区| 交换的一天中文字幕在线视频| 91精品国产综合99| 蜜桃臀少妇白色紧身裤细高跟| 黑吊操欧美极品美女| 国产av精品一区二区三区久久| av毛片在线观看网址| 中文字幕久久久国产| 97视频人人爱麻豆| 自拍丝袜国产欧美日韩| 在线免费观看视频18| 国产igao激情在线视频入口| 999久久久人妻精品一区| 午夜情色一区二区三区| 99久久国语露脸国产精品| 91超碰国产在线观看| 91精品资源在线观看| 人妻女侠被擒受辱记| 最新国产精品综合网高清| 99久久碰碰人妻国产| 日韩欧美中文字幕老司机三分钟| 999久久久人妻精品一区| 欧美成人一二三在线网| 成人大片男人的天堂| 国产精品亚洲精品亚洲| 亚洲精品1卡2卡3卡| 日韩三级精品电影久久久久| 青青操91美女国产| 精品国产污污污污免费观看| 午夜精品秘一区二区三区| 欧美日韩精品aaa| 中文字幕人妻一区二区视频系列| 国产午夜在线播放视频| 亚洲制服丝袜资源网| 亚洲综合一区二区三区四区| 色屁屁一区二区三区在线观看| 99久久人人爽亚洲精品美女| 无人区一码二码三码区别在哪| 岳的大肥屁熟妇五十路| 久久久亚洲综合国产精品| 强乱人妻中文字幕日本| 中文字幕麻绳捆绑的人妻| 亚洲色视频在线播放网站| 在线 激情 亚洲 视频| 国产熟女五十路一区二区三区| 国产成人综合久久婷婷| 欧洲精品在线免费观看| 亚洲精品9999蜜桃| 99久久国产精品免费消防器材| 日本有码精品一区二区三区| av天堂hezyo| 欧美男女一区二区三区| 天天干天天操天天要| 97精品久久久久久无码人妻| 玖辛奈18禁同人污本子| 中文字幕观看中文字幕免费 | 69国产在线视频网站| 视频在线+欧美十亚洲曰本| 男女69视频在线观看免费| 亚洲av手机免费在线| 2020国产激情视频在线观看| 日本成人福利电影网| aaaa级少妇高潮在线观看| 国产,亚洲,欧美综合| 亚洲资源在线免费观看| 岳母的诱惑电影在线观看| 日本高清久久人人爽| 97精品视频,全部免费| 人妻少妇的va视频| av在线播放观看h| www一区二区91| 最新中文字幕久久久久| 久久久精品人妻无码专区不卡| 婷婷色综合五月天视频| 熟女国内精品一区二区三区| av激情四射五月婷婷| 2019年中文字幕在线播放视频| 98热视频精品在线观看| 夜夜操夜夜爱夜夜摸| 亚洲乱码国产乱码精品精视频| 国产精品网站亚洲发布| 成年人黄色日本视频| 天天操天天搞天天操| 看女人大BB群伦交| 国产91黑丝小视频在线观看| 91精品国产成人久久久久久| 在线免费观看视频18| 欧美成人屋影院在线视频观看| 亚洲最强的25个城市| 黑人侵犯人妻森泽佳奈| 顶级欧美色妇xxxx| 狠狠操深爱婷婷综合一区| tobu8日本高清| 中文字幕欧美人妻在线.| 日韩一级欧美一级片| 大奶熟妇激情操逼逼| 日本少妇丰满大bbb的小乳沟| aaaa级少妇高潮在线观看| 美女欧美视频在线观看免费| 亚洲在线观看中文字幕av| 亚洲欧美一级特黄大片| 在线免费观看欧美小视频| 加勒比东京热绿帽人妻多人操| 国产毛片特级Av片| 在线观看免费啪啪啪| 国产精品视频网站污污污| 亚洲免费午夜污福利| 欧美黑人性猛交小矮人| 色狠狠色综合久久久绯色| 国模伊人久久精品一区二区三区| 在线观看中文字幕视频成人| 老熟女xxxⅹhd老熟女性| 亚洲一区二区三区四区入口| 亚洲国产中文字幕在线看| 欧美日韩久久丝袜在线| 五月婷婷激情视频网| xxxx69在线观看视频| 成人午夜av电影网| 中文字幕日本一二三区| 欧美日韩综合精品无人区| 中文字幕免费啪啪啪| 精品人妻在线激情视频| 黄色片黄色片黄色片黄色片黄色| 日韩人妻精品久久久久| 国产91九色视频在线观看| 深夜福利免费观看在线看| 18禁男女啪啪啪无遮挡| 免费中文字幕a级激情| 中文字幕一区二区三区久久久| 中文字幕免费啪啪啪| 亚洲综合色一区二区三区| 亚洲自拍偷拍一区二区中文字幕| 亚洲免费在线不卡视频| 中国特黄色性生活片| 福利一二三在线视频观看| 日本一区二区高清av中文| 国产天堂av不卡网| 亚洲图片另类综合小说| 男人用大鸡巴狂操女人肉穴| 狠狠干狠狠操免费视频| 国产视频成人一区二区| 最新中文字幕久久久久| 午夜精品秘一区二区三区| 天天干天天操天天要| 亚洲自拍偷拍一区二区中文字幕 | 亚洲黄色免费在线观看网站| 日韩一区二区在线播放观看| 国产成人情侣激情视频| 婷婷综合缴情亚洲五月伊人| 欧美一级aaaaaaa片| 国内自拍第一区二区三区| 日韩激情文学在线视频| 国产美女视频带a∨黄色片| 久久国产精品久精国产爱| 亚洲av激情综合网| 18在线观看免费观看| 核xp工厂精品久久亚洲| 夜夜躁av麻豆男| 欧美一区二区三区爽爽| 亚洲免费在线不卡视频| 欧美成人少妇人妻精品| 婷婷色综合五月天视频| 人妻中文字幕亚洲在线| 九九热视频1这里只有精品| 快进来插我的逼嗯啊视频| 360偷拍蜜桃臀69式| 亚洲色视频在线播放网站| 99国产精品国产精品毛片19| 女人的天堂 av在线| 看女人大BB群伦交| 成年男女免费视频网站无毒| 中文字幕 首页 人妻| 久久亚洲国产成人精品麻豆 | 96在线观看免费播放| 91麻豆精品国产在线| 久久免费视频ww一区| 51vv精品视频在线观看| 天天摸天天舔天天操天天日| 中文字幕熟女乱一区二区| 超级黄肉动漫在线观看| 亚洲精品激情视频在线观看| 天天插天天操天天射天天干| 欧美一区二区播放视频| 97cao在线视频| 日本少妇熟女乱码一区二区| 91精品久久久久久久99蜜月| 色欲AV蜜桃一区二区三| 国产成人在线观看视频播放| 午夜92福利1000| 黄色网络中文字幕日本| 亚洲中文字幕在线av| 999精品视频免费在线观看| 久久99嫩草99久久精品| 黄色片免费国产精品| 国产男人的天堂一区| 亚洲熟妇在线视频观看| 伊人网在线欧美日韩在线| 天天碰天天摸天天搞| 亚洲午夜高清在线观看| 国产成人深夜福利短视频99| 中文字幕福利视频在线一区| 成人免费电影二区三区| 中文字幕精品人妻久久久久| 日本一本午夜在线播放| 日本少妇人妻凌辱在线| 一级做性色a爱片久久片| 不卡一区二区视频在线| 91 精品视频在线看| 五月天色婷婷狠狠爱| 9662av在线视频| 天天插天天操天天射天天干| 在线观看中文字幕精品av| 青青免费观看视频| 夜色福利视频免费观看| 亚州av嫩草av极品在线观看| 一区二区三区四区影片| 亚洲va999天堂va| 懂色av之国产精品| 精品国产人伦一区二区三区| 国产av在线免费视频| 黄片视频免费观看视频| 成人午夜av电影网| 成人午夜高清福利视频| 美女欧美视频在线观看免费| 九九热在线精品播放| 欧美区日本区国产区| 神马不卡视频在线视频| 最新日韩中文字幕免费在线观看| 黄色网络中文字幕日本| 宅男噜噜噜66国产在线观看| 欧美亚洲愉拍一区二区三区| 亚洲韩精品一区二区三区| 天天操天天射天天操天天日| 亚洲国产电影的一区| 免费在线观看亚洲福利| 免费中文字幕a级激情| 欧美成人短视频在线播放| 日本欧美视频在线免费| 99久久碰碰人妻国产| 天天操天天射天天操天天日| 自拍偷自拍亚洲精品10p| 日韩三级精品电影久久久久| 天天天天天天天天干夜夜| 黑人侵犯人妻森泽佳奈| 一区二区九日韩美女| 18在线观看免费观看| 四季av人妻一区二区三区| 欧美亚洲精品色图网站| 中文字幕久久久国产| 亚洲自拍偷拍av在线| 国产夫妻视频在线观看免费| 天天躁狠狠躁狠狠躁性色| 中文字幕在线观看av观看| 久久一级片三上悠亚| 国产中文亚洲熟女日韩| 51vv精品视频在线观看| 免费在线观看亚洲福利| 99热在线只有的精品| 天天弄天天草天天日天天| 最新国产精品拍在线观看| 亚洲色视频在线播放网站| 欧美在线观看一区二区不卡| 麻豆国产精品777777在| 久久99热精品免费观看视| 日韩人妻中文字幕区| 制服丝袜 中文字幕 日韩| 亚洲男人天堂最新网址大全| 成人资源中文在线观看| 日本老熟妇av老熟妇| 91进入蜜桃臀在线播放| 亚洲国产日韩欧美一区二区三区, 精久久久久久久久久久久 | 国产人妻熟女ⅹxx丝袜| 黄色大片一级老太太操逼| 婷婷一区二区三区五月丁| v天堂国产精品久久| 中文字幕亚洲无线乱码| 九九热精品视频在线播放| 亚洲码av一区二区三区| 中文字幕人妻一区色偷偷久久| 午夜精品老牛av一区二区三区| 中文字幕日韩人妻在线三区| 先锋人妻啪啪中文字幕| 亚洲精品9999蜜桃| 四虎国产精品国产精品国产精品 | 不卡一二三区别视频| a级黄片免费观看| 日韩一级视频一区二区三区| 天天碰天天摸天天搞| 欧美人与动欧交视频| 神马不卡视频在线视频| 抽插小穴啊啊啊视频| 亚洲熟女一区二区三区250p| 蜜臀一区二区日韩美女少妇视频| 亚洲午夜精品一级毛片app| 狂操鸡巴小骚逼视频免费观看| 国产精品网站的黄色| 黄色大片一级老太太操逼| 亚洲午夜熟女在线观看| 在线观看视频免费一区二区三区| 999国产精品视频免费看| 猫咪亚洲中文在线中文字幕| 欧美在线观看视频欧美| 亚洲综合一区二区三区四区| 一区二区三区婷婷中文字幕| 精品不卡一区二区三区| 午夜在线成人免费电影| 熟女一区二区视频在线| 日本熟女0930视频| 婷婷色九月综合激情丁香| 妈妈的朋友中字在线免费观看| 中文乱码字幕人妻熟女人妻| 成人资源中文在线观看| 91九色pony蝌蚪| 天天看天天爱天天日| 黄在线看片免费人成视频| 中文字幕日韩人妻在线三区| 日本一区二区三区调教性奴视频| 日韩精品视频一区二区三区在线 | 免费看日韩黄视频在线观看| 丰满少妇高潮喷水视频| 亚洲欧美综合另类最新| 豆豆专区操逼性视频在线 | 69精品互换人妻4p| xxxx69在线观看视频| 青青在线视频看看| 91激情四射婷婷综合| 可在线免费观看av| 九色porny91国产| 人妻激情综合久久久久蜜桃| 亚洲免费午夜污福利| 欧美男女一区二区三区| 裸日本资源在线午夜| 污网址在线观看视频| 亚洲国产精品 久久久| 国产精品igao为爱寻找激情| 69国产在线视频网站| 美女欧美视频在线观看免费| v天堂国产精品久久| 精品精品精品精品精品污污污污| av激情四射五月婷婷| 91超精品碰国产在线观看| 人人妻人人狠人人爽| 91人妻人人爽色啊啊啊| 老熟妇一区二区三区v∧88| 超碰在线pro中文字幕| 国产一级一国产一级毛片| 免费24小时人妻视频| 亚洲欧美韩国日本一区二区| 中出小骚货在线观看| 中文字幕熟女乱一区二区| 999国产精品视频免费看| 内地精品毛片在线观看| 男人用大鸡巴狂操女人肉穴| 国产男女无套?免费网站下载 | 狠狠干狠狠操免费视频| 成人免费视频现网站99在线观看| 最新中文字幕久久久久| 国产福利一区二区三区在线观看 | 汤姆提醒30秒中转进站口| 可在线免费观看av| av天堂a亚洲va天堂va里番| 国产精品免费看一区二区三区| 成人精品动漫一区二区| 日韩一区二区在线播放观看| 亚洲同性同志一二三专区| yy4080黄色片| 在线观看2022av| 亚洲天堂av最新在线| 69精品互换人妻4p| 国产精品亚洲精品亚洲| 97精品视频,全部免费| 亚洲欧美精品海量播放| 亚洲国产精品自拍偷拍视频在线| 91大神在线免费观看视频| 欧美亚洲另类精品第一页| 天天干天天弄天天日| 成人人妻h在线观看| 天天操天天干加勒比久久| 国产清纯一区二区在线观看| 精品欧美黑人一区二区三区| 亚洲高清免费在线观看视频| 国产最新av在线免费观看| 天天综合久久无人区| 黑川堇人妻88av| 亚洲一区视频中文字幕在线播放 | 天堂av在线最新地址| 亚洲av手机免费在线| 亚洲AV无码久久精品国产一区老| 91系列视频在线播放| 中文字幕在线免费观看人妻| 国产人妻熟女ⅹxx丝袜| 天天干天天操天天要| 在线国产精品欧美| 女女抠逼白虎白丝袜| 九九六视频,这里只有精品 | 18禁男女啪啪啪无遮挡| 夫亡人妻被强干中文字幕| 99久久精品视频16| av丝袜免费在线观看| 中文字幕精品人妻久久久久| 熟女一区二区视频在线| 黄在线看片免费人成视频| 亚洲 综合 欧美 一区| 午夜精品久久久久久久精品乱码| 欧美vr专区日韩vr专区| 青青操天堂在线观看视频| 亚洲一区二区精品在线播放| 美利坚合众国av天堂| 青娱乐免费最新视频| 操烂你的骚逼天天欧美| 成人午夜高清福利视频| 亚洲黑人欧美二区三区| 亚洲欧美另类校园春色| 成人精品影视一区二区| 亚洲色视频在线播放网站| 色狠狠色综合久久久绯色| 欧美日韩不卡视频合集 | 亚洲av中文无码网站| 九九热在线精品播放| 99久久久久久亚洲精品免费| 午夜精品久久久久久久久久蜜桃 | 国产精品 亚洲欧美 自拍偷拍| avgo成人短视频| 日韩加勒比精品在线看| 大香焦一道本一区二区三区| 亚洲av 综合av| 精品日本少妇久久久| 天天天天天天天天干夜夜| 亚洲综合一区二区三区四区| 18福利视频在线观看| 日韩人妻中文字幕区| 久草视频在线看免费| 亚洲国产精品自产拍在线观看| 新亚洲天堂男子av| 日本老女人日比视频| 国产精品美女免费视频观看| 美女张开腿给男人桶爽的软件| 2020国产成人精品视频| 51精品视频在线免费观看| 青娱乐免费视频一二三| 国产青青青青草免费在线视频| 台湾18禁久久久久久久激情视频| 亚洲成年人精品国产| v天堂国产精品久久| 美女网站视频久久精品| 午夜情色一区二区三区| 亚洲一区二区在线视频观看免费| 天堂av在线最新地址| 99久久久久久亚洲精品免费| 天天早上头和脸出汗是怎么办| 77亚洲视频在线观看| 免费啪啪啪网站在线观看| 国产激情视频在线观看的| 360偷拍蜜桃臀69式| 天天干夜夜操夜夜骑| 婷婷一区二区三区五月丁| 中文在线字幕免费观看日韩视频| 日本欧美视频在线免费| 男女爱爱好爽视频免费看| 99久久国产精品免费热| 一区二区三区 国产日韩欧美| 中文字幕精品人妻久久久久| 超碰在线观看97资源| 69精品互换人妻4p| 亚洲av网站一区二区三区| 欧美日韩综合精品无人区| 91亚洲国产成人久久精品| 97精品久久久久久无码人妻| 黄很色很在线免费视频网站 | 中文字幕在线观看av观看| 大尺度av毛片在线网址| 夏目彩春av在线看| 上床啪啪啪免费视频| 国产黑色丝袜 在线日韩欧美| 在线视频自拍第三页| 一区二区三区四区 在线播放| 一区二区三区四区视频精品免费| 2020年亚洲男人天堂网| 天天日夜夜操人人爽| 91精品久久久久久久99蜜月| 免费的啪啪视频软件 | 国产毛片特级Av片| 可在线免费观看av| av丝袜免费在线观看| 蜜乳av中文字幕一区二区| 亚洲精品综合欧美精品综合| 国产午夜羞羞一区二区三区| 亚洲男人天堂最新网址大全 | 男插女视频大全免费| 手机看电影一区二区三区| 黄很色很在线免费视频网站| 岛国av成人午夜高清| 欧美性感美女热舞视频| 中文字幕中文字幕在线中…一区| 开心激情五月天作爱片| 国产成人av在线你懂得| 91porny九色视频偷拍| 在线看的免费网站黄| 国产精品福利久久久久| 男女啪啪啪啪91av日韩| 精品国产久久久久午夜精品av| 伊人网在线免费观看| 成人精品动漫一区二区| 911精产国品一二三产区区| 亚洲欧美精品日韩偷拍| av在线播放观看h| 二十四小时日本高清在线观看 | 一区二区三区四区影片| 国产精美视频精品视频精品| 美女网站视频久久精品| 99热99这里免费的精品| 精品国产无乱码一区二区三区| 快使劲弄我视频在线播放| 污网址在线观看视频| 91超碰九色porny| 手机看片福利一区二区三区四区| 一区二区三区高清视频3| 久久久人妻免费视频| 亚洲高清免费在线观看视频| 最新日韩中文字幕啪啪啪| 欧美亚洲精品色图网站| 91污污在线观看视频| 久久久久国产精品二区| 亚洲一区二区在线激情| 最近最新欧美日韩精品| 成人人妻h在线观看| 日本老女人日比视频| 国产igao激情在线视频入口| 亚洲自拍偷拍一区二区中文字幕 | 亚欧洲乱码视频一二三区| 精品国产污污污污免费观看| 美女露阴道让男人捅| 老司国产精品视频免费观看| 青青操天堂在线观看视频| 亚洲av三级电影在线观看| 中文字幕人妻精品精品| 69视频在线精品国自产拍| 手机看片1024精品国产| 激情久久在线免费观看视频| 干逼又爽又黄又免费的视频| 九九热在线精品播放| 国产免费久久精品99re丫丫| 午夜8050免费小说| 亚洲蜜桃久久久久久| 熟女一区二区视频在线| 啪啪啪网站免费看视频| 大成色亚洲一二三区| 蜜乳视频一区二区三区| 丝袜美腿日韩av一区| 欧美色区国产日韩亚洲区| 国产视频1区2区3区| 全国熟妇精品一区二区免费视频| 55夜色66夜色亚洲精品| 最新久久这里只有精品| 中文字幕人妻精品精品| 夜夜操天天干夜夜操| 国产自拍偷拍在线精品| 91亚洲国产成人久久精品| 精品日本少妇久久久| 中国精品人妻一区二区| 自拍偷自拍亚洲精品10p| 亚洲熟妇丰满多毛xxxx网站| 自拍偷拍 国产激情| 久久久久夜色国产精品电影| 最新激情中文字幕视频| 亚洲欧美一级特黄大片| 成人黄色录像在线观看| 插鸡视频免费网站在线播放| 成人午夜av电影网| 大屁股熟女一区二区视频| 欧美视频免费观看777| 欧美一区二区播放视频| 在线有码人妻自拍视频| 欧美日本在线免费视频| 3344永久在线观看视频下载| 免费高清av一区二区| 欧美一级日韩一级亚洲一级va| 日本熟女0930视频| 91亚洲精品久久蜜桃| 国际日韩日韩日韩日韩日韩| 精产国品一二三产品区别91| 新亚洲天堂男子av| 欧美一区日韩二区三区四区| 大尺度av毛片在线网址| 国产免费久久精品99re丫丫 | 91美女在线观看视频| 美女福利网站在线播放| 91亚洲精品久久蜜桃| 91精品国产成人久久久久久| 欧美最新一区二区三区| 日本不卡视频一二三区| 视频自拍偷拍视频自拍| 久99久视频免费观看中文字幕| 人妻系列在线免费视频| 国产午夜羞羞一区二区三区| 红桃视频国产av在线| 亚洲第一成年偷拍视频| 丰满少妇人妻一区二区三区蜜桃| 在线人成视频免费观看尤物| 中文字幕人妻精品精品| 久久精品国产亚洲av热软件| 韩国资源视频一区二区三区| 五十岁熟妇高潮喷水| 亚洲美女色www色| 中文字幕人妻一区二区视频系列 | av激情四射五月婷婷| 日本清纯中文字幕版| 国产夫妻视频在线观看免费| 亚洲国产精品自拍偷拍视频在线 | 国产av在线免费视频| 桃色成人开心激情网| 天天早上头和脸出汗是怎么办| 人妻系列在线免费视频| 一区二区三区av免费天天看| 亚洲三级综合在线观看| 男插女视频大全免费| 极品风骚人妻3p视频| 在线视频自拍第三页| 亚洲欧美小说中文字幕| 青青在线免费手机播放视频| 西野翔人妻中文字幕中字在| 77亚洲视频在线观看| 波多野结衣在线一区别| 亚洲在线观看中文字幕av| 国产在线小视频一区二区| 日本a级2020在线观看| 亚洲经典av中文字幕| 精品国产污污污污免费观看| 蜜桃臀少妇白色紧身裤细高跟| tobu8日本高清| 日本少妇人妻中文在线| 亚洲一区二区三区国产精品电影| 男女爱爱好爽视频免费看| 婷婷六月天在线视频| 亚洲制服丝袜美腿在线| 欧美操大黑鸡巴视频在线观看| 360偷拍蜜桃臀69式| 亚洲综合成人精品成人精品| 快进来插我的逼嗯啊视频| 日本黄页在线观看视频| 99在线视频精品观看高| 加勒比不卡在线视频| 亚洲国产精品久久久久久无码| 人妻少妇精品二三区| 久久中文字幕av一区二区| 日本一区二区三区区别| 亚洲第一成年偷拍视频| ass亚洲熟女ass| 911精产国品一二三产区区| 欧美久久蜜臀蜜桃资源吧| 青青青免费手机视频在线观看| 女人的天堂 av在线| 五月天色婷婷狠狠爱| 亚洲综合一区二区三区四区| 亚洲成人五月婷婷久久综合 | 国产福利三级在线观看| 黄色片免费网站在线| 午夜情色一区二区三区| 亚洲人人爽人人澡起碰av| 免费在线观看黄色小网站| 国内精品一区二区2021在线| 可以直接看av网站| 午夜久久久久欠久久久久| 9420高清视频在线观看国语版| 91精品夜夜夜一区二区蜜桃| 国产女人18毛片水真多精选| av大尺度一区二区三区| 国产视频1区2区3区| 亚洲国产精品久久久久久无码| 偷拍欧美日韩另类图片| 9420高清视频在线观看国语版| 中文字幕欧美一区二区视频| 国产精品无码无卡免费观| 99精品久久精品一区二区| 青青草一个释放的网站| 日本免费人爱做视频在线观看不卡 | 一二区二区不卡视频| 美女福利网站在线播放| 人人妻人人狠人人爽| 日本久久久久久黄色| 九九热精品视频在线播放| 天天干夜夜操夜夜骑| 欧美一区日韩二区三区四区| 国产清纯一区二区在线观看| 欧美日韩一区二区三区成人影院| 人妻色综合aaaaaa网| 美国男的操女孩的小嫩逼| 女生裸体视频免费网站| 免费中文字幕a级激情| 人妻人妻在线视频网站| 看女人大BB群伦交| 人妻激情综合久久久久蜜桃| 99热这里只有精品免费播放| 川上优所有中文字幕在线| 亚洲美女露隐私av一区二区精品 | 大陆中文字幕视频在线| 国产精品免费看一区二区三区| 伊人精品久久一区二区| 中文字幕av人妻一区二区三区| 人人妻人人狠人人爽| 精品国模一区二区三区欧美| 亚洲精品一区二区gif| 欧美最新一区二区三区| 西野翔人妻中文字幕中字在| 国产精品igao为爱寻找激情| 2026天天操天天干| 午夜精品久久久久久久精品乱码| 午夜福利在线不卡视频| 亚洲av手机免费在线| 日本丰满熟妇浓密多毛| yellow在线亚洲精品一区| 97精品久久久久久无码人妻| 69国产在线视频网站| 国产成人情侣av在线| 女生抠逼自慰啊啊啊啊啊啊啊下载| 欧美一区二区播放视频| av天堂hezyo| 亚洲制服丝袜网站中文字幕| 在线免费视频999| 久久久久久久久久久久久国产| 三区美女视频在线观看| 中文人妻av一区二区三区| 2021国产在线视频| 91在线九色porny| 东北老女人熟女啪啪视频| 中文字幕亚洲无线乱码| 欧美日韩成人高清中文网| 天天夜夜久久精品综合| 99精品久久99久久久久一| 色丁香久久激情综合网| 999精品视频免费在线观看| 日韩人妻中文字幕区| 网友自拍第一页99热| 天天躁狠狠躁狠狠躁性色| 人人妻人人爽人人摸| 日韩国产欧美一区二区三区粉嫩| 天天操天天舔天天爽| 91色哟哟视频在线观看| 高清国产美女a一级毛片| 成人免费视频现网站99在线观看 | 男人的天堂在线2025| xxxx69在线观看视频| 日本亚洲午夜福利一区二区三区| 中文字幕人妻精品精品| 亚洲AV无码一二三四区在线播放| 小妹妹爱大棒棒免费观看视频| 日韩精品视频一区二区三区在线| 亚洲熟妇在线视频观看| 2020国产成人精品视频| 久久99国产中文丝袜| 日韩欧美黄色免费网站| 丝袜美女诱惑佐佐三上| 色噜噜噜噜色噜噜色合久一| 亚洲国产美女主播在线观看| 成人午夜麻豆大胆视频| 天天日夜夜操人人爽| 少妇精品视频一区二区免费看| 男女啪啪啪啪91av日韩| 中文字幕 人妻 熟女| 日韩美精品成人一区二区三区四区| 最新中文字幕久久久久| 亚洲高清一区二区三区久久| 亚洲中文字幕在线视频观看二区| 男人和女人的逼视频| 久久内射天天玩天天懂色| 色狠狠色综合久久久绯色| 91精品国产91久久久久久密臀| 日本熟妇乱妇熟色视频| 91大神在线免费观看视频| 精品久久久久久久久久久久久| 熟妇高潮久久久久久久| 两个奶被揉得又硬又翘怎么回事| 亚洲综合首页综合在线观看| 老司国产精品视频免费观看| 青青草一个释放的网站| 69久久夜色精品国产69乱电影| 全球高清中文字幕av| 亚洲第一中文字幕成人| 九色91操最新在线观看网址| 亚洲中文字幕最新地址| 亚洲一级熟妇丰满的女人| 欧美日韩成人高清中文网| 日本老熟妇av老熟妇| 亭亭五月天在线观看| 亚洲经典av中文字幕| 欧美精品乱码99久久蜜桃免费| 网站在线观看蜜臀91| 亚洲成a人片777777张柏芝| 男人和女人的逼视频| 91香蕉国产亚洲一二三区| 亚洲美女露隐私av一区二区精品| 91精品麻豆91夜夜骚| 啊~插得好快别揉我胸了视频| 成人av中文字幕在线看| 熟女国内精品一区二区三区 | 亚洲欧美激情久久久| 中文乱码字幕人妻熟女人妻| 欧美在线视频不卡一区| 得得爱在线视频观看| 中国精品人妻一区二区| 国产男女无套?免费网站下载 | 99精品久久99久久久久一| 午夜精品小视频在线播放| 手机看片1024精品国产| 漂亮人妻口爆久久精品| 97超碰人人爽人人做| 亚洲国产日韩精品在线| 日本一本午夜在线播放| 中文字字幕在线精品乱码| 久久久亚洲熟女一区二区| 亚洲同性同志一二三专区 | 国产精品久久久99| 青青在线免费手机播放视频| 日韩成人精品久久久免费看| a级黄片免费观看| 精品国产人伦一区二区三区| 成人免费视频现网站99在线观看| 99热99这里免费的精品| 人妻系列中文字幕大乳丰满人妻| 欧美日本国产一区二区| 日本熟女0930视频| 川上优所有中文字幕在线| 日本五六十路熟女视频| 91福利高清在线播放| 美女黄色啊啊啊啊视频| 午夜宅男电影av网站| 精品高潮呻吟久久av| 在线 激情 亚洲 视频| 国产免费久久精品99re丫丫| 天天操天天舔天天射天天日天天干 | 久久99精品热在线观看| 首页欧美日韩中文字幕| 夜夜人人干人人爱人人操| 1区3区4区产品乱入视频| 每日更新日韩欧美在线| 可以直接看av网站| 开心激情五月天作爱片| 久久久久久a女人处女| iga肾三级算严重吗| 欧美成人一二三在线网| 久久热在线免费观看| 欧美区日本区国产区| ysl蜜桃色7425| 丰满人妻被猛烈进入中文字幕| lutu玩弄人妻短视频| 亚洲 自拍 激情 另类| 日韩久久九九精品视频| 老熟妇一区二区三区v∧88| 2020国产激情视频在线观看| 婷婷色九月综合激情丁香| 亚洲欧美小说中文字幕| 1区3区4区产品乱入视频| 可以直接看av网站| 色噜噜噜噜色噜噜色合久一| 久草视频在线视频在线视频| 360偷拍蜜桃臀69式| 亚欧洲乱码视频一二三区| 一区二区三区四区视频精品免费| 国产成人综合久久婷婷| 欧美男男在线观看视频网站| 午夜8050免费小说| jiee日本美女视频网站| av资源中文字幕在线观看| 亚洲三级综合在线观看| 美女把逼扒开让男人桶| 国色天香一二三期区别大象| 羞羞漫画无限免费观看秋蝉| 日本少妇人妻凌辱在线| 日韩人妻一区二区三区在线观看 | 户外露出视频在线观看| 亚洲第一成年偷拍视频| 99999久久久精品| 国产亚洲综合5388| 91色哟哟视频在线观看| 欧美黄色性视频网站| 最新日韩中文字幕免费在线观看| 精品欧美黑人一区二区三区| 国产自拍偷拍在线精品| 国产精品内射婷婷一级| 少妇被粗大的猛进69视频| av在线免费在线观看| 宅男噜噜噜66国产在线观看| 欧美久久一区二区伊人| 不用付费特黄特色亚洲特级黄色片| 久久久国产精品免费视频网| 男人资源站中文字幕| 天天日夜夜操人人爽| 欧美日本在线免费视频| 日本少妇三级交换做爰做| 在线免费视频999| 蜜桃臀少妇白色紧身裤细高跟| 天天透天天舔天天操| 国语精品视频自产自拍| 岳母的诱惑电影在线观看| 亚洲综合天堂av网站在线观看| 制服丝袜 中文字幕 日韩| 性高潮视频在线观看日韩| 日本老女人日比视频| 五月婷婷激情视频网| 欧美情色av在线观看| 4438x亚洲最大的成人| 人妻在线中文视频视频| av成人三级高清日韩| 98热视频精品在线观看| 伊人精品成人综合网| 日本老熟老熟妇七十路| 天天早上头和脸出汗是怎么办| 三级欧美日韩一区二区三区| 最近最新最好看的中文字幕| 亚洲制服丝袜在线看| 黑鸡巴肏少妇逼视频| 黑人侵犯人妻森泽佳奈| 91日本精产品一区二区三区| 鸡巴插进美女的嫩小穴视频| 日本电影一级人妻在线播放四区| jizzjizz国产精品传媒| 91精品国产人妻麻豆| 美女激情久久久久久久| 国产激情在线观看一区二区三区| 久久久西西gogo日本美女人体| 亚洲成人偷拍自拍在线| 日本成人福利电影网| 欧美在线观看视频欧美| 东京热日本一区二区三区| 69精品人妻久久久久久久久久久 | 人妻少妇的va视频| av天堂新资源在线| 一区二区三区四区视频精品免费| 98热视频精品在线观看| 4日日夜夜精品视频免费| 亚洲av毛片在在线播放| 亚成区一区二区人妻熟女| 欧美日韩国产在线中文字幕| 青青在线免费手机播放视频| 夜夜爽夜夜操夜夜爱| 高清av在线婷一区二区色日韩| 最新国产午夜激情视频| 汤姆提醒30秒中转进站口| 91九色尤物无套内射| 国产精品久久久99| 国产主播诱惑毛片av| 亚洲国产精品一区51动漫| 国产,亚洲,欧美综合| 国产精品免费看一区二区三区| 九九热精品视频在线播放| 亚洲人妻系列在线视频| 久久久久久a女人处女| 天天摸天天干夜夜操| 欧美男男在线观看视频网站| 一区二区三区资源视频| 2021国产剧情麻豆| 91污污在线观看视频| 青娱乐免费最新视频| 亚洲18片综合国产av| 国产av在线免费视频| 亚洲欧美国产一本综合首页| 人妻超清中文字幕在线乱码| 亚洲女人自熨在线视频| 亚洲 偷拍 自拍 欧美| 一区二区三区 国产日韩欧美| 69av精品国产探花| 亚洲gay视频在线观看| 午夜久久久久欠久久久久| 亚洲熟女人妻自拍在线视频| 岛国av成人午夜高清| 精品av天堂毛片久久久| 中文字幕福利视频第四页| av在线男人的天堂亚洲| 日韩欧美中文字幕老司机三分钟| 97香蕉久久国产超碰| 大香蕉在线欧美在线视频| 久99久视频免费观看中文字幕| 欧美人与动欧交视频| caopeng97在线观看视频| 亚洲成年人精品国产| 三区美女视频在线观看| 亚洲18片综合国产av| 伊人网在线欧美日韩在线| 欧美日韩亚洲国产视频二区| 亚洲欧洲无码一区2区无码| 不卡在线一区二区三区| 国产女人18毛片水真多精选| 福利视频免费在线播放| 啊~插得好快别揉我胸了视频| 男人资源站中文字幕| 久久sm人妻中出精品一区二区| 日本黄页在线观看视频| 人妻免费视频黄片在线视频| 操死你美女在线视频| 4日日夜夜精品视频免费| 成人午夜av电影网| 交换的一天中文字幕在线视频 | 182tv精品免费在线观看| 天天操天天射天天操天天日| 性感美女人妻久久久| 亚洲欧美韩国日本一区二区| 亚洲欧美成人激情在线| 国产精品igao为爱寻找激情| 天天摸天天干夜夜操| 亚洲国内精品久久久久久久| 中国精品人妻一区二区| 国产在线小视频一区二区| 天天插天天操天天射天天干| 久久精品久久久久观看99水蜜桃| 亚洲a区在线免费观看| 荣立三等功退休有什么待遇| 港台美女明星av天堂| 松本菜奈实最新av在线| 精品一区二区三区喷水内射高潮| 少妇被粗大的猛进69视频| 无人区一码二码三码区别在哪| 免费成人av麻豆| 最新国产午夜激情视频| 日韩人妻中文字幕区| 丰满人妻熟女aⅴ一区| 人妻少妇视频系列视频在线| 中文字幕熟女人妻一区| 亚洲欧美日韩中文在线观看| 波多野结衣在线一区别| 偷拍熟女大胆免费视频| 9662av在线视频| 欧美人与动欧交视频| 亚洲免费午夜污福利| 黄色av 在线观看| 天天干夜夜操夜夜骑| 日韩人妻中文字幕区| 精品人妻人人做人人爽| 港台美女明星av天堂| 中文字幕观看中文字幕免费| 特级aaaaa黄色片| 大香蕉尹人在线最新| 色噜噜噜噜色噜噜色合久一| 亚洲成人自拍图片网站| 久久久精品人妻无码专区不卡| 九九视频在线观看全部| 鸡巴插进美女的嫩小穴视频| 国产人妻777人伦精品hd超碰| 亚洲精品综合欧美精品综合| 国产高清自拍偷拍在线| 亚洲第一页欧美第一页| 青青青免费手机视频在线观看| 国产夫妻视频在线观看免费| 亚洲熟女乱色一区二区三区视频 | 亚洲国产精品久久久久久无码| 日韩免费黄色片在线观看| 亚欧洲乱码视频一二三区| 亚洲综合一区二区三区四区| 天天操天天舔天天做| 久久一级片三上悠亚| 国产在线小视频一区二区| 欧美男男在线观看视频网站| 人妻色综合aaaaaa网| 熟妇人妻丰满久久久久久久| 亚洲一区二区精品三区视频| 福利视频导航在线观看| 日本成年视频在线免费观看| 五月婷婷激情视频网| 天天操天天干加勒比久久| 亚洲欧美日韩电影一区| 午夜免费福利老司机| 美女张开腿给男人桶爽的软件| 91大神福利视频网| 911精产国品一二三产区区| 日韩一级欧美一级片| 核xp工厂精品久久亚洲| 七色福利视频在线观看| 亚洲色图日韩在线视频观看| 激情久久在线免费观看视频| 欧美久久一区二区伊人| 黑人侵犯人妻森泽佳奈| 亚洲成人自拍av在线| 人妻激情偷乱一区二区三区av| 91亚洲最新蜜桃在线| 91香蕉国产亚洲一二三区| 日韩人妻中文字幕二区| 青娱乐免费视频一二三| 无码人妻丰满熟妇区五路| 无人区一码二码三码区别在哪| 99999久久久精品| 在线视频国产精品欧美| 天天操天天干天天谢| 日本熟妇乱妇熟色视频| 激情九月天在线视频| 人妻免费视频黄片在线视频| 92在线播放观看视频| 日本香港韩国三级黄色| 人妻激情偷乱一区二区三区av| 亚洲18片综合国产av| 久久久人妻免费视频| 日本福利片在线播放| 久久久久高潮白浆久久| 亚洲乱码av一区二区蜜桃av| 中文字幕日本一二三区| 国产一区二区三区四区精| 最新国产精品综合网高清| 成人av中文字幕在线看| 黑人侵犯人妻森泽佳奈| 亚洲av激情综合网| 欧美黄色一区二区三区视频| 一级毛片特级毛片免费的| 久久久久久久精品乱码| 免费啪啪啪网站在线观看| 久久精品国产亚洲av热软件| 美女张开腿给男人桶爽的软件| 2020国产激情视频在线观看| 少妇精品视频一区二区免费看| 在线 制服 中文字幕 日韩| 岛国av成人午夜高清| 亚洲欧美小说中文字幕| 99久久精品视频16| 夜夜爽夜夜操夜夜爱| 夜夜躁av麻豆男| 精品国模一区二区三区欧美| 亚洲成人av在线一区二区| 欧美色区国产日韩亚洲区| 欧美极品少妇高潮喷水| 午夜福利国产精品久久久久| 天天干天天色综合久久| 69精品人妻久久久久久久久久久| 伊人精品久久一区二区| 久久久久国产精品二区| 亚洲激情噜噜噜久久久| av大尺度一区二区三区| 开心五月综合激情婷婷| 99re这里是国产精品首页| 美女福利网站在线播放| 69国产精品成人aaaaa片| 丰满人妻熟女aⅴ一区| 久久久久夜色国产精品电影| 青青草原在线播放日韩| 亚洲人成大片在线观看| 男女爱爱好爽视频免费看 | 久久99热精品免费观看视| 91精产国品一二三产区区别网站| 核xp工厂精品久久亚洲| 中文字幕 中文字幕 亚洲| 美女黄色啊啊啊啊视频| 亚洲综合在线视频在线播放| 精久久久久久久久久久久| 国产在线小视频一区二区| 国产av啊啊啊啊啊啊啊| 91香蕉国产亚洲一二三区| 天天看天天爱天天日| 色丁香久久激情综合网| 啊~插得好快别揉我胸了视频| 乌克兰美女操逼高清内射视频| 顶级欧美色妇xxxx| 中出小骚货在线观看| 日本不卡视频一二三区| 亚洲一区二区三区国产精品电影| 日韩女同与成人用品电影免费看| 免费观看在线中文字幕视频| 60路70路日本熟妇| 天堂网免费在线电影| 国产精品 亚洲欧美 自拍偷拍 | 3344永久在线观看视频下载| 亚洲一区二区三区国产精品电影| 抽插小穴啊啊啊视频| 中文字幕福利视频在线一区| 欧美一区二区播放视频| 亚洲中文字幕无线乱码人妻精品| 免费24小时人妻视频| 91精品视频在线观看视频| 婷婷一区二区三区五月丁| 台湾18禁久久久久久久激情视频| 亚洲综合首页综合在线观看| 中文字幕免费啪啪啪| 综合激情网,激情五月| 狠狠操深爱婷婷综合一区| 日本在线免费观看国产精品| tushy一区二区三区视频| 日本清纯中文字幕版| 一看就是假奶的av| 国产 亚洲 欧美 自拍| 精久久久久久久久久久久| 亚洲一区视频中文字幕在线播放| 午夜精品久久久久久久精品乱码| 日本a级2020在线观看| 欧美性受黑人猛交裸体视频| 美女网站视频久久精品| 日本男女免费福利视频| 大尺度久久久久久久| 男生和女生羞羞91在线看| 不用付费特黄特色亚洲特级黄色片| 18福利视频在线观看| 玖玖资源站在线观看亚洲| 日本亚洲精品视频在线观看| 欧美一区日韩二区三区四区| 在线观看中文字幕精品av| 日本老女人日比视频| 日韩成人免费观看电影| 绿巨人浩克在线视频观看| 人妻少妇精品二三区| 在线观看免费啪啪啪| 国产一区两区三区福利小视频| 亚洲欧美国产一本综合首页| 日韩国产欧美一区二区三区粉嫩| 亚洲少妇视频在线观看| 久久热在线免费观看| 欧美精品激情在线不卡| 老鸭窝在线毛片观看免费播放| 韩日一级人添人人澡人人妻精品| 天天早上头和脸出汗是怎么办| 夏目彩春av在线看| 日本欧美高清在线观看视频| 国产精品 亚洲欧美 自拍偷拍| 精品一区二区三区免费毛片W| 婷婷综合缴情亚洲五月伊人| 丰满人妻被猛烈进入中文字幕| 人妻系列中文字幕大乳丰满人妻| 亚洲欧美日韩中文在线观看| 亚洲最大先锋资源采集站| 夫妻黄色一级性生活片| 午夜福利国产精品久久久久| 绿巨人浩克在线视频观看| 国产美女视频带a∨黄色片| 亚洲成人,国产精品| 欧美丝袜亚洲国产日韩| 凹凸视频一区二区在线观看| 18禁网站在线点击观看| 黄很色很在线免费视频网站| 国产不卡免费在线观看| 东京热日韩av在线| 国产精品网站的黄色| 亚洲高清一区二区三区久久| lutu玩弄人妻短视频| 可在线免费观看av| 国产成人91色精品免费看片| 亚洲美女黄色福利视频网站大全| 成人午夜高清福利视频| 中文字幕麻绳捆绑的人妻| 精品精品精品精品精品污污污污| 91精品国产91久久久久久密臀| 免费在线观看视频啪啪| 欧美成人区一区二区三| 性高潮视频在线观看日韩 | 国产精品午夜无码AV体验区| 欧洲精品在线免费观看| 有码一区二区三区四区五区| 天天干天天色综合久久| 99精品久久一区二区 | 亚洲男人的天堂最新网址| 九九热在线精品播放| 欧美久久蜜臀蜜桃资源吧| 99色在线观看免费观看| 男人av一区二区三区| 欧美精品999不卡| 漂亮人妻口爆久久精品| 黄色av日韩在线观看| 九九六视频,这里只有精品| 在线观看免费啪啪啪| 天堂av国产av伦理av| 天天干天天色综合久久| 日本熟妇乱妇熟色视频| 亚洲第一成年偷拍视频| 区一区二区三免费观看视频| 伊人网在线欧美日韩在线| 核xp工厂精品久久亚洲| 青青青青午夜手机国产视频| 99久久久久久久久久久久久| 九九热精品视频在线播放| 国内自拍第一区二区三区| 天天早上头和脸出汗是怎么办| 欧美成人屋影院在线视频观看| 中文在线字幕免费观看日韩视频| 男女啪啪啪啪91av日韩| 日韩久久不卡免费视频| 亚洲熟女乱色一区二区三区视频| 汤姆提醒30秒中转进站口| 两个奶被揉得又硬又翘怎么回事| 性感美女人妻久久久| 不用付费特黄特色亚洲特级黄色片| 亚洲gay视频在线观看| 琪琪日本福利伦理视频| 4438x亚洲最大的成人| 国产福利一区二区三区在线观看| 69久久夜色精品国产69乱电影| 91亚洲国产成人久久精品| 亚洲一区二区三区无码在线| av在线观看视频免费| 9999久久久久老熟妇二区| 新亚洲天堂男子av| 后入日韩翘臀蜜桃臀美女|