MYSQL INNODB索引

來源:互聯網
上載者:User

標籤:mysql 索引最佳化

    

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

   

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

    

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


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


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


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

本文出自 “堅持學習” 部落格,請務必保留此出處http://8906256.blog.51cto.com/8896256/1629362

MYSQL INNODB索引

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.