Mysql调优:深入理解Mysql索引底层数据结构与算法

1. 索引的本质

索引是帮助Mysql高效获取数据的排好序的数据结构。Mysql索引底层数据结构采用的是B+ tree
在这里插入图片描述

  • B+ tree中一个节点存储在一个页中,一个页的大小大概16KB
  • 非叶子结点不存储data,只存储索引(冗余),可以放更多的索引
  • 叶子结点包含所有的索引字段
  • 叶子结点用指针连接,提高区间访问的性能
show global status like 'innodb_page_size';

在这里插入图片描述

数据库表与文件的对应关系

在这里插入图片描述

2. 索引的实现

MyISAM存储引擎索引实现
在这里插入图片描述

索引放在MYI文件中,MYD文件中,MyISAM索引文件和数据文件时分离开的。(MyISam的主键为非聚集索引)

InnoDB存储引擎索引实现

  • 表数据文件(ibd)文件本身就是按照B+ tree组织的一个索引结构文件
  • 聚集索引-叶节点保护了完整的数据记录
  • 为什么建议InnoDB表必须建立主键(由InnoDB下数据的存储情况就可以知道为什么要建立索引),并且推荐整型的自增索引 (整型索引在排序和存储方面都有优势,自增索引在构建B+树时可以减少结点分裂操作的次数,提高B+树构建的效率)
  • 为什么非主键所有结构叶子结点存储的是主键值,而不是数据本身?
    答:是为了数据的一致性和节约存储空间

在这里插入图片描述

3. 联合索引(实际使用比较多)

联合索引结构在这里插入图片描述

联合索引底层是如何排序的?
答:会按照建立索引的顺序来依次排序,如果第一个字段已经能够排序,后面的字段就无需考虑了,如果存在多个相同的第一个索引列的数据,那么这几个数据之间再使用第二个索引进行排序,依次类推直到排序完成。(这也是最左前缀法则的原理)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值