成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

MyISAM與InnoDB的索引,究竟有什么差異?

開發 開發工具 MySQL
數據庫的索引分為主鍵索引(Primary Inkex)與普通索引(Secondary Index)。InnoDB和MyISAM是怎么利用B+樹來實現這兩類索引,其又有什么差異呢?這是今天要聊的內容。

數據庫的索引分為主鍵索引(Primary Inkex)與普通索引(Secondary Index)。InnoDB和MyISAM是怎么利用B+樹來實現這兩類索引,其又有什么差異呢?這是今天要聊的內容。

[[419863]]

一、MyISAM的索引

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

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

  • 有連續聚集的區域單獨存儲行記錄;
  • 主鍵索引的葉子節點,存儲主鍵,與對應行記錄的指針;
  • 普通索引的葉子結點,存儲索引列,與對應行記錄的指針;

畫外音:MyISAM的表可以沒有主鍵。 主鍵索引與普通索引是兩棵獨立的索引B+樹,通過索引列查找時,先定位到B+樹的葉子節點,再通過指針定位到行記錄。

舉個例子,MyISAM:

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

表中有四條記錄:

  • 1, shenjian, m, A
  • 3, zhangsan, m, A
  • 5, lisi, m, A
  • 9, wangwu, f, B

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

  • 行記錄單獨存儲;
  • id為PK,有一棵id的索引樹,葉子指向行記錄;
  • name為KEY,有一棵name的索引樹,葉子也指向行記錄;

二、InnoDB的索引

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

  • 沒有單獨區域存儲行記錄;
  • 主鍵索引的葉子節點,存儲主鍵,與對應行記錄(而不是指針);

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

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

  • 如果表定義了PK,則PK就是聚集索引;
  • 如果表沒有定義PK,則第一個非空unique列是聚集索引;
  • 否則,InnoDB會創建一個隱藏的row-id作為聚集索引; 

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

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

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

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

  • 不建議使用較長的列做主鍵,例如char(64),因為所有的普通索引都會存儲主鍵,會導致普通索引過于龐大;
  • 建議使用趨勢遞增的key做主鍵,由于數據行與索引一體,這樣不至于插入記錄時,有大量索引分裂,行記錄移動;

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

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

表中還是四條記錄:

  • 1, shenjian, m, A
  • 3, zhangsan, m, A
  • 5, lisi, m, A
  • 9, wangwu, f, B

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

  • id為PK,行記錄和id索引樹存儲在一起;
  • name為KEY,有一棵name的索引樹,葉子存儲id;

當:

  1. select * from t where name=‘lisi’; 

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

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

三、總結

MyISAM和InnoDB都使用B+樹來實現索引:

  • MyISAM的索引與數據分開存儲;
  • MyISAM的索引葉子存儲指針,主鍵索引與普通索引無太大區別;
  • InnoDB的聚集索引和數據行統一存儲;
  • InnoDB的聚集索引存儲數據行本身,普通索引存儲主鍵;
  • InnoDB一定有且只有一個聚集索引;
  • InnoDB建議使用趨勢遞增整數作為PK,而不宜使用較長的列作為PK;

【本文為51CTO專欄作者“58沈劍”原創稿件,轉載請聯系原作者】

戳這里,看該作者更多好文 

 

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2018-08-27 16:15:20

數據庫MyISAMInnoDB

2015-10-14 17:54:01

容器虛擬機云服務

2020-03-29 08:19:56

程序員代碼

2021-02-23 19:29:57

智能網卡SmartNIC網絡

2022-09-09 07:41:35

DatabricksSnowflake數據

2010-05-21 16:10:28

2018-06-14 10:44:59

MySQLMyISAMInnoDB

2021-10-11 15:57:49

物聯網5G技術

2020-03-24 14:48:12

DevOps敏捷區別

2020-09-16 08:54:24

物聯網IOT物聯網技術

2017-04-12 12:50:31

人工智能谷歌AlphaGo

2010-11-23 11:27:53

MySQL MyISA

2021-01-17 16:29:51

C++Python語言

2022-10-26 09:02:07

致態

2015-02-27 09:45:25

搶紅包手機

2013-01-08 10:02:26

虛擬化云計算

2013-01-06 09:55:36

虛擬化云計算

2018-08-03 10:39:13

快閃

2009-03-13 08:56:31

Symbian手機OS諾基亞

2011-08-25 12:51:02

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久久久久久久 | 91精品国产一区二区在线观看 | 欧美久久久久 | 天天综合久久 | 久草在线 | 精品国产一区久久 | 国产精品久久久久久久久久久久久 | 国产亚洲一区二区三区 | 国产高清在线 | 精国产品一区二区三区 | 手机在线观看 | 欧美激情久久久 | 国产一级一级毛片 | 玖玖久久 | 日本国产一区二区 | 亚洲精选一区二区 | 日本精品一区二区三区四区 | 欧美黄页| 久久精品影视 | 国产精品久久久久一区二区三区 | 一区二区三区免费观看 | 精精国产xxxx视频在线野外 | 黄免费观看视频 | 亚洲一区二区三区在线观看免费 | 国产精品高潮呻吟久久久久 | 久久国产三级 | 欧美精品三区 | av永久| 欧美一级二级视频 | 91久久国产精品 | 久久久123| 三级成人片 | 免费久久网 | 81精品国产乱码久久久久久 | 亚洲欧美在线免费观看 | 亚洲高清电影 | 亚洲一区二区三区在线 | 国产精品无码专区在线观看 | 久久99蜜桃综合影院免费观看 | 91精品国产综合久久福利软件 | 欧美中文字幕在线观看 |