91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyISAM與InnoDB的索引的區別

發布時間:2020-06-06 15:51:52 來源:億速云 閱讀:972 作者:Leah 欄目:MySQL數據庫

相信大部分人都不太了解MyISAM與InnoDB的索引的區別,今天小編為了讓大家更加了解MyISAM與InnoDB的索引的區別,給大家總結了以下內容,跟隨小編一起來看看吧。

B+樹,它是一種非常適合用來做數據庫索引的數據結構:

(1)很適合磁盤存儲,能夠充分利用局部性原理,磁盤預讀;

(2)很低的樹高度,能夠存儲大量數據;

(3)索引本身占用的內存很小;

(4)能夠很好的支持單點查詢,范圍查詢,有序性查詢; 

數據庫的索引分為主鍵索引(Primary Inkex)與普通索引(Secondary Index)。

一,MyISAM的索引

MyISAM的索引與行記錄是分開存儲的,叫做非聚集索引(UnClustered Index)。

 

其主鍵索引與普通索引沒有本質差異:

有連續聚集的區域單獨存儲行記錄

主鍵索引的葉子節點,存儲主鍵,與對應行記錄的指針

普通索引的葉子結點,存儲索引列,與對應行記錄的指針

畫外音:MyISAM的表可以沒有主鍵。

 

主鍵索引與普通索引是兩棵獨立的索引B+樹,通過索引列查找時,先定位到B+樹的葉子節點,再通過指針定位到行記錄。

 

舉個例子,MyISAM:

t(id PK, name KEY, sex, flag);

 

表中有四條記錄:

1, shenjian, m, A

3, zhangsan, m, A

5, lisi, m, A

9, wangwu, f, B
MyISAM與InnoDB的索引的區別
 

其B+樹索引構造如上圖:

行記錄單獨存儲

id為PK,有一棵id的索引樹,葉子指向行記錄

name為KEY,有一棵name的索引樹,葉子也指向行記錄

 

二、InnoDB的索引

InnoDB的主鍵索引與行記錄是存儲在一起的,故叫做聚集索引(Clustered Index):

沒有單獨區域存儲行記錄

主鍵索引的葉子節點,存儲主鍵,與對應行記錄(而不是指針)

畫外音:因此,InnoDB的PK查詢是非常快的。

 

因為這個特性,InnoDB的表必須要有聚集索引:

(1)如果表定義了PK,則PK就是聚集索引;

(2)如果表沒有定義PK,則第一個非空unique列是聚集索引;

(3)否則,InnoDB會創建一個隱藏的row-id作為聚集索引;

 

聚集索引,也只能夠有一個,因為數據行在物理磁盤上只能有一份聚集存儲。

 

InnoDB的普通索引可以有多個,它與聚集索引是不同的:

普通索引的葉子節點,存儲主鍵(也不是指針)

 

對于InnoDB表,這里的啟示是:

(1)不建議使用較長的列做主鍵,例如char(64),因為所有的普通索引都會存儲主鍵,會導致普通索引過于龐大;

(2)建議使用趨勢遞增的key做主鍵,由于數據行與索引一體,這樣不至于插入記錄時,有大量索引分裂,行記錄移動;

 

仍是上面的例子,只是存儲引擎換成InnoDB:

t(id PK, name KEY, sex, flag);

 

表中還是四條記錄:

1, shenjian, m, A

3, zhangsan, m, A

5, lisi, m, A

9, wangwu, f, B
MyISAM與InnoDB的索引的區別

其B+樹索引構造如上圖:

id為PK,行記錄和id索引樹存儲在一起

name為KEY,有一棵name的索引樹,葉子存儲id

 

當:

select * from t where name=‘lisi’;

MyISAM與InnoDB的索引的區別

會先通過name輔助索引定位到B+樹的葉子節點得到id=5,再通過聚集索引定位到行記錄。

畫外音:所以,其實掃了2遍索引樹。

看完上述內容,你們對MyISAM與InnoDB的索引的區別大概了解了嗎?如果想了解更多相關文章內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

同江市| 泸溪县| 文登市| 建瓯市| 长岭县| 金沙县| 昭苏县| 海伦市| 庆云县| 旺苍县| 渝中区| 雷山县| 万山特区| 鲁甸县| 和平县| 宜州市| 襄城县| 博兴县| 黎城县| 涿鹿县| 高尔夫| 北流市| 晋江市| 轮台县| 新野县| 绵阳市| 同德县| 盘山县| 泸州市| 九寨沟县| 望都县| 吉水县| 三亚市| 伊宁县| 刚察县| 逊克县| 卓资县| 凌海市| 海盐县| 阿拉善盟| 盘山县|