Mysql索引底层结构的分析

本文深入探讨了Mysql索引的底层结构,从二叉树、红黑树到最终选用的B+Tree。分析了不同数据结构的优缺点,强调了B+Tree在处理大量数据时的优势,如叶子节点间的指针连接,以及InnoDB存储引擎中主键索引与非主键索引的区别。此外,还解释了为何推荐使用整形主键和自动增长特性。
摘要由CSDN通过智能技术生成

索引是帮助mysql快速获取数据的数据结构,索引的本质就是一种数据结构。

目的是提高查询效率,类比字典。

也可以理解为 排好序的快速查找数据结构

数据库系统除了存储数据之外,还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用指向数据,这样就可以在这些数据结构上实现高级查找算法,这种数据结构就是索引。例如下图就是一种可能的索引方式实例:
在这里插入图片描述

如果不加索引,Mysql在底层的执行过程其实是把每一行数据记录从磁盘读取到内存中,然后进行查询条件的比对,每一次读取数据都是一次磁盘IO。早期的Mysql索引还考虑过采用二叉树和红黑树的数据结构,首先根据sql查询条件去找索引树,找到一个节点之后就将存储的value值取出来,这个value值就是对应该数据在磁盘中的物理地址。查询索引的节点也相当于一次磁盘io。

如果选二叉树的数据结构会有一些缺点,就比如上图Col1字段,一直是一个自增的列,那这个时候索引的二叉树就会变为:

在这里插入图片描述
红黑树和二叉树相比较的话,那就是红黑树当一边的节点太多时,它会自动的进行一个树的旋转优化,红黑树也叫二叉平衡树

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值