聚簇索引與非聚簇索引的區別

2022-09-22 02:51:09 字數 558 閱讀 6750

眾所周知,索引是關係型資料庫中給資料庫表中一列或多列的值排序後的儲存結構,sql的主流索引結構有b+樹以及hash結構,聚集索引以及非聚集索引用的是b+樹索引。這篇文章會總結sql server以及mysql的innodb和myisam兩種sql的索引。

sql sever索引型別有:唯一索引,主鍵索引,聚集索引,非聚集索引。

mysql 索引型別有:唯一索引,主鍵(聚集)索引,非聚集索引,全文索引。

(1)聚集索引

聚集索引是指資料庫錶行中資料的物理順序與鍵值的邏輯(索引)順序相同。乙個表只能有乙個聚集索引,因為乙個表的物理順序只有一種情況,所以,對應的聚集索引只能有乙個。如果某索引不是聚集索引,則表中的行物理順序與索引順序不匹配,與非聚集索引相比,聚集索引有著更快的檢索速度。

(2)非聚集索引

非聚集索引是一種索引,該索引中索引的邏輯順序與磁碟上行的物理儲存順序不同。

參考部落格:聚簇索引和非聚簇索引的理解

聚簇索引與非聚簇索引區別

聚集索引與非聚集索引的區別是 葉節點是否存放一整行記錄 innodb 主鍵使用的是聚簇索引,myisam 不管是主鍵索引,還是二級索引使用的都是非聚簇索引。下圖形象說明了聚簇索引表 innodb 和非聚簇索引 myisam 的區別 聚簇索引與非聚簇索引 1.對於非聚簇索引表來說 右圖 表資料和索引是...

聚簇索引與非聚簇索引

聚簇索引介紹 聚簇索引並不是一種單獨的索引型別,而是一種資料儲存方式。具體的細節依賴於實現方式,例innodb的聚簇索引實際上在同乙個結構中儲存了b tree索引和資料行。當表有聚簇索引時,他的資料行實際放在索引的葉子頁 leaf page 術語 聚簇 聚簇索引實現 儲存引擎負責實現索引,因此不是所...

聚簇索引與非聚簇索引

mysql的索引主要使用b 樹和雜湊索引的方式進行組織。雜湊索引底層即是雜湊表,查詢時只需要進行一次雜湊操作即可得到位址,查詢速度比較快,但是查詢時操作只適合 的查詢操作,對於範圍查詢不友好,因此只適用於大多數需求為單錶查詢的情況。mysql中常用的兩大引擎myisam和innodb 對於b 樹的使...