MySQL的索引類型包括B+樹索引、哈希索引和全文索引,其中B+樹索引是應用最廣泛的一種。但是,在B+樹索引的基礎上,MySQL還有一種比較特殊的索引類型——二叉索引。
所謂二叉索引,就是將B+樹的分支數(shù)從多叉變成二叉,即每個節(jié)點只有左子樹和右子樹兩個分支。
+--12+ +--9+--| +--7| +--13+ | +--5+ | | +--15+ | +--11| | | +--20+ --+ +--17| | | +--25+ 5 +--19| +--30+
上圖展示了一個二叉索引的樣例,可以看到每個節(jié)點都只有左右兩個子節(jié)點,這樣雖然會增加樹的高度,但也會減少每個節(jié)點的開銷。
二叉索引適用于那些讀多寫少和數(shù)據(jù)不頻繁變化的表。由于二叉索引對于插入和刪除操作的開銷較大,所以不適合那些頻繁更新的數(shù)據(jù)表。
在MySQL中,二叉索引并沒有單獨的選項來創(chuàng)建,而是作為普通索引的一種形態(tài)存在。如果你希望創(chuàng)建一個二叉索引,只需要在創(chuàng)建索引時添加關鍵字“BTREE”即可。
CREATE INDEX idx_name ON table_name (column_name) USING BTREE;
當然,如果你不希望使用二叉索引,也可以將BTREE關鍵字省略不寫,這樣就會使用默認的B+樹索引。
無論是B+樹索引還是二叉索引,都可以提高數(shù)據(jù)庫的查詢效率。但是由于兩種索引類型存在許多差異,所以在實際使用中需要根據(jù)自己的需求來選擇相應的索引類型。