MYSQL INNODB索引

    

    在MYSQL中索引是在存儲引擎實現的,所以各個存儲引擎中的索引的實現方式是不一樣的。本章節主要是學習INNODB存儲引擎中最常用的索引類型:聚簇索引和B-Tree索引

   

    在INNODB存儲引擎中表其實是oracle中類似的聚簇表而不是普通的堆表。INNODB根據主健的順序存儲數據,數據直接存儲在主健的葉子節點上面。數據即索引,索引即數據。因此爲了讓數據儘可能的按照主健的順序存儲在一起innodb還專門設計了一個Insert buffer機制來保證(但不能百分之百的保證)。如果數據根據主健值隨機插入則會導致大量的拆頁操作,不僅會影響插入的效率同樣會影響其他查詢操作增加隨機I/O讀。

    

    當然聚簇索引按照key的順序插入數據在某些高併發的情況下也會導致一些其他的問題。比如間隙索和自增鎖(如果使用了自增列的話)


    上面提到的主健,如果不指定會怎麼樣呢? innodb會默認使用第一個唯一索引作爲key,如果都不存在則會虛擬出一個key來實現。


    除了主健索引其他的都稱之爲"二級索引",爲什麼成之爲二級索引呢?


    因爲在其他普通的索引(B-Tree索引)中存儲的並不是存儲的記錄的物理地址而是行號(主健值),根據主健值然後在去到聚簇索引中去找到該行的位置,找到了行的位置也即找到了數據。還是因爲聚簇索引的"數據即索引,索引即數據"。因此不難理解按照主健插入數據有多麼重要了吧。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章