innodb作為事務型數據庫的首選引擎,支持ACID事務,支持行級鎖定,支持外鍵。并且InnoDB默認地被包含在MySQL二進制分發中,已經成為絕大多數OLTP系統的直選存儲引擎。
索引作為數據庫開發的一個重要方面,對于訪問性能以及能否支持高并發,高tps的應用,起著決定性作用。Innodb存儲引擎支持B+樹索引以及自適應哈希索引,其中后者是由innodb引擎根據表的使用情況自動生成,無法進行人為創建。
B+樹索引是目前關系型數據庫中最常見最有效的索引,是基于二分查找而形成的一棵平衡術結構。我們來逐步了解。
MySQL就普遍使用B+Tree實現其索引結構
索引的主要作用:
1、快速定位記錄
2、避免排序和使用臨時表
3、可以將隨機IO變為順序IO