索引是一种加快查询速度的数据结构,经常使用索引结构有hash、B-Tree和B+Tree。本节经过分析三者的数据结构来讲明为啥Mysql选择用B+Tree数据结构。mysql
hash是基于哈希表完成索引存储,哈希表特性是数据存放是散列的。算法
优势:sql
等值查询快,经过hash值直接定位到具体的数据。数据结构
缺点:性能
B-Tree特色:优化
B+Tree 是在B-Tree的基础之上作的一种优化,变化以下:3d
Mysql官网文档中写到InnoDB索引用的是 B-tree,可是底层用的是B+Tree。Mysql存储数据是以页为单位,默认一个页能够存放16K数据。假设B-Tree和B+Tree都是3层深度,表中每一个记录为1K(假设的,通常不会这么大,别较真),那么三层深度的B-Tree存储 16 x 16 x 16 = 4096(比这个数还要少,由于每一个页中还要存放指针和其它的数据)。B+Tree第1、二层存放的是key,假设是Long类型的主键,那么第1、二层每页存放数据约为 16 x 1024 / 8 = 2048,三层深度能够存放 2048 x 2048 x 16 = 6700W。MySQL查询过程是按页加载数据的,每加载一页就是一次IO操做,B+Tree进行三次IO能够查询6700W数据量。从这里也能够知道Mysql通常设置三层深度就足够了。指针