亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

深入講解MySQL Innodb索引的原理

2024-07-25 19:09:15
字體:
來源:轉載
供稿:網友

引言

回想四年前,我在學習mysql的索引這塊的時候,老師在講索引的時候,是像下面這么說的

索引就像一本書的目錄。而當用戶通過索引查找數據時,就好比用戶通過目錄查詢某章節的某個知識點。這樣就幫助用戶有效地提高了查找速度。所以,使用索引可以有效地提高數據庫系統的整體性能。

嗯,這么說其實也對。但是呢,大家看完這種說法,其實可能還是覺得太抽象了!因此呢,我還想再深入的細說一下,所以就有了此文!

需要說明的是,我說的內容只在Mysql的Innodb引擎中是成立的。在Sql Server、oracle、Mysql的Mysiam引擎中的正確性,不一定成立!

InnoDB是 MySQL最常用的存儲引擎,了解InnoDB存儲引擎的索引對于日常工作有很大的益處,索引的存在便是為了加速數據庫行記錄的檢索。

什么是索引?

索引(index)翻譯為一個目錄,用于快速定位我們想要找的數據的位置。例如:我們把一個數據庫比作一本書,而索引(index)就是書中的目錄,此刻要找到書的某個感興趣的內容,我們一般是不會整本書翻完再去確認該內容在哪里,而是通過書的目錄,定位到該內容章節所在頁數,最后直接翻到該頁面。

我們來看看在數據庫中的索引:

全表掃描 VS 索引掃描

以字典為例,全表掃描就是如果我們查找某個字時,那么通讀一遍新華字典,然后找到我們想要找到的字,而跟全表掃描相對應的就是索引查找,索引查找就是在表的索引部分找到我們想要找的數據具體位置,然后會到表里面將我們想要找的數據全部查出。

OK,廢話不多說,開始啰嗦!

正文

索引的科普

先引進聚簇索引和非聚簇索引的概念!

我們平時在使用的Mysql中,使用下述語句

CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name [USING index_type] ON tbl_name (index_col_name,...) index_col_name: col_name [(length)] [ASC | DESC]

創建的索引,如復合索引、前綴索引、唯一索引,都是屬于非聚簇索引,在有的書籍中,又將其稱為輔助索引(secondary index)。在后文中,我們稱其為非聚簇索引,其數據結構為B+樹。

那么,這個聚簇索引,在Mysql中是沒有語句來另外生成的。在Innodb中,Mysql中的數據是按照主鍵的順序來存放的。那么聚簇索引就是按照每張表的主鍵來構造一顆B+樹,葉子節點存放的就是整張表的行數據。由于表里的數據只能按照一顆B+樹排序,因此一張表只能有一個聚簇索引。

在Innodb中,聚簇索引默認就是主鍵索引。

這個時候,機智的讀者,應該要問我

如果我的表沒建主鍵呢?

回答是,如果沒有主鍵,則按照下列規則來建聚簇索引

沒有主鍵時,會用一個唯一且不為空的索引列做為主鍵,成為此表的聚簇索引如果沒有這樣的索引,InnoDB會隱式定義一個主鍵來作為聚簇索引。

ps:大家還記得,自增主鍵和uuid作為主鍵的區別么?由于主鍵使用了聚簇索引,如果主鍵是自增id,,那么對應的數據一定也是相鄰地存放在磁盤上的,寫入性能比較高。如果是uuid的形式,頻繁的插入會使innodb頻繁地移動磁盤塊,寫入性能就比較低了。

索引原理介紹

先來一張帶主鍵的表,如下所示,pId是主鍵

 

pId name birthday
5 zhangsan 2016-10-02
8 lisi 2015-10-04
11 wangwu 2016-09-02
13 zhaoliu 2015-10-07

 

畫出該表的結構圖如下

MySQL,Innodb,索引

如上圖所示,分為上下兩個部分,上半部分是由主鍵形成的B+樹,下半部分就是磁盤上真實的數據!那么,當我們, 執行下面的語句

select * from table where pId='11'

那么,執行過程如下

MySQL,Innodb,索引

如上圖所示,從根開始,經過3次查找,就可以找到真實數據。如果不使用索引,那就要在磁盤上,進行逐行掃描,直到找到數據位置。顯然,使用索引速度會快。但是在寫入數據的時候,需要維護這顆B+樹的結構,因此寫入性能會下降!

OK,接下來引入非聚簇索引!我們執行下面的語句

create index index_name on table(name);

此時結構圖如下所示

MySQL,Innodb,索引

大家注意看,會根據你的索引字段生成一顆新的B+樹。因此, 我們每加一個索引,就會增加表的體積, 占用磁盤存儲空間。然而,注意看葉子節點,非聚簇索引的葉子節點并不是真實數據,它的葉子節點依然是索引節點,存放的是該索引字段的值以及對應的主鍵索引(聚簇索引)。

如果我們執行下列語句

select * from table where name='lisi'

此時結構圖如下所示

MySQL,Innodb,索引

通過上圖紅線可以看出,先從非聚簇索引樹開始查找,然后找到聚簇索引后。根據聚簇索引,在聚簇索引的B+樹上,找到完整的數據!

什么情況不去聚簇索引樹上查詢呢?

還記得我們的非聚簇索引樹上存著該索引字段的值么。如果,此時我們執行下面的語句

select name from table where name='lisi'

此時結構圖如下

MySQL,Innodb,索引

如上圖紅線所示,如果在非聚簇索引樹上找到了想要的值,就不會去聚簇索引樹上查詢。還記得,博主在《select的正確姿勢》提到的索引問題么:

當執行select col from table where col = ?,col上有索引的時候,效率比執行select * from table where col = ? 速度快好幾倍!

看完上面的圖,你應該對這句話有更深層的理解了。

那么這個時候,我們執行了下述語句,又會發生什么呢?

create index index_birthday on table(birthday);

此時結構圖如下

MySQL,Innodb,索引

看到了么,多加一個索引,就會多生成一顆非聚簇索引樹。因此,很多文章才說,索引不能亂加。因為,有幾個索引,就有幾顆非聚簇索引樹!你在做插入操作的時候,需要同時維護這幾顆樹的變化!因此,如果索引太多,插入性能就會下降!

總結

講到這里,大家應該清楚的明白索引的原理了!可能細節方面還不夠嚴謹,但是我覺得一個研發,理解到這里可以了,夠用了,畢竟我們也不是專業的DBA。
希望大家有所收獲!


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩一区二区在线| 日韩av手机在线观看| 精品久久久久久久久久国产| 日韩av电影在线免费播放| 日韩精品免费综合视频在线播放| 国产精品专区第二| 亚洲自拍欧美另类| 国模吧一区二区| 久久这里只有精品99| 超碰91人人草人人干| 亚洲精品美女免费| 亚洲一区二区三区乱码aⅴ| 亚洲免费av网址| www.日韩系列| 91精品国产成人| 羞羞色国产精品| 欧美在线一级视频| 亚洲国产精品va在线看黑人动漫| 亚洲精品av在线| 热99精品里视频精品| 丝袜一区二区三区| 国产精品久久不能| 国产精品久久久久免费a∨大胸| 欧美一级黑人aaaaaaa做受| 中文字幕亚洲二区| 国产精品久久久久久婷婷天堂| 欧美激情性做爰免费视频| 国产精品999| 在线日韩第一页| 国产专区欧美专区| 国内伊人久久久久久网站视频| 91久久嫩草影院一区二区| 久久久天堂国产精品女人| 精品久久久免费| 2021国产精品视频| 精品日韩中文字幕| 精品国内亚洲在观看18黄| 亚洲乱亚洲乱妇无码| 亚洲国产美女精品久久久久∴| 欧美性生活大片免费观看网址| 午夜精品久久久久久久久久久久| 国产精品日韩在线一区| 亚洲精品第一页| 日韩一二三在线视频播| 姬川优奈aav一区二区| 国产精品久久久久久久久久ktv| 在线电影欧美日韩一区二区私密| 国产狼人综合免费视频| 国产精品美女av| 亚洲国产精品热久久| 亚洲成人性视频| 亚洲 日韩 国产第一| 亚洲视频日韩精品| 久久综合久久八八| 色悠悠久久88| 国产区亚洲区欧美区| 中文字幕欧美精品日韩中文字幕| 中文字幕在线日韩| 欧美日本高清视频| 国产精品日日做人人爱| 69久久夜色精品国产69| 欧美激情综合色综合啪啪五月| 97国产精品人人爽人人做| 国产高清视频一区三区| 亚洲天堂av高清| 成人激情视频网| 国产精品久久久久久久久久东京| 中文字幕国产亚洲2019| 亚洲精品久久久久久久久久久久久| 国产精品久久久久久久久久尿| 中文字幕一区电影| 91系列在线播放| 尤物九九久久国产精品的分类| 精品国产网站地址| 欧美午夜激情视频| 亚洲xxxx18| 国产免费一区视频观看免费| 久热精品在线视频| 一区二区亚洲欧洲国产日韩| 97视频在线观看免费高清完整版在线观看| 欧美日韩亚洲国产一区| 欧美精品激情视频| 国产精品美女久久久久av超清| 国产亚洲视频在线| 欧美日韩国产999| 久久人人爽人人| 国产午夜精品麻豆| 久久久久久有精品国产| 国产亚洲日本欧美韩国| 亚洲免费视频在线观看| 国产精品成人久久久久| 久久久久国产精品一区| 久久精品在线播放| 在线观看精品国产视频| 日韩在线精品一区| 欧洲永久精品大片ww免费漫画| 亚洲一区二区三区乱码aⅴ| 亚洲人成亚洲人成在线观看| 超薄丝袜一区二区| 日韩精品中文字幕在线播放| 国产精品对白刺激| 国模精品系列视频| 日韩精品在线私人| 国产精品久久久久77777| 欧美精品在线播放| 福利微拍一区二区| www.久久久久久.com| 亚洲国产欧美精品| 国内精品久久久久影院优| 欧美日韩成人在线视频| 亚洲四色影视在线观看| 久久免费少妇高潮久久精品99| 亚洲国产精久久久久久久| 欧美日韩xxxxx| 亚洲一区二区三区777| 成人在线免费观看视视频| 庆余年2免费日韩剧观看大牛| 国产精品69精品一区二区三区| 国产福利精品av综合导导航| 国产成人精品日本亚洲| 欧美黄色片在线观看| 欧美性理论片在线观看片免费| 中文字幕久热精品视频在线| 国产在线拍揄自揄视频不卡99| 国产主播欧美精品| 国产视频欧美视频| 热99久久精品| 亚洲97在线观看| 日产精品久久久一区二区福利| 久久精品视频一| 全球成人中文在线| 国产日韩中文字幕| 欧美激情一区二区三区成人| 亚洲一区二区三区四区在线播放| 欧洲成人午夜免费大片| 国产区亚洲区欧美区| 欧美在线观看视频| 国产精品日韩欧美| 欧美大胆a视频| 国产91精品黑色丝袜高跟鞋| 亚洲国内高清视频| 奇米影视亚洲狠狠色| 一区二区三区动漫| 91精品国产91久久久久久久久| 久久久电影免费观看完整版| 成人激情视频小说免费下载| 久久91亚洲精品中文字幕| 精品久久香蕉国产线看观看亚洲| 国产精品久久久久久久久久免费| 亚洲国产高潮在线观看| 欧美另类69精品久久久久9999| 亚洲天堂成人在线视频| 国产精品一二三视频| 欧美日韩在线免费观看| 国产成人综合精品在线| 欧美成人免费网| 97视频免费在线观看| 精品视频在线播放色网色视频| 亚洲第一av在线| 亚洲影影院av| 97精品视频在线观看| 亚洲新中文字幕| 日韩av电影在线网| 亚洲精品在线不卡|