MySQL - InnoDB联合索引的数据结构是什么?

回到顶部(go to top)

总结

  • 对于联合索引来说只不过比单值索引多了几列。
  • 联合索引的所有索引列都出现在索引树上,并依次顺序比较几个列的大小。
  • InnoDB引擎会首先根据第一个索引列“单调递增”排序,如果第一列相等则再根据第二列排序,依次类推.

必看例子:

数据表T1有字段a,b,c,d,e,其中a是主键,除e为varchar其余为int类型,并创建了一个联合索引idx_t1_bcd(b,c,d),然后b、c、d三列作为联合索引:

 

 

 

(b,c,d) 联合索引的所有索引列都出现在索引数上,并依次比较b,c,d三列的大小。

bcd联合索引在B+树上的结构图

 

 

当我们的SQL语言可以应用到bcd联合索引的时候,比如 select * from T1 where b = 12 and c = 14 and d = 3; 也就是T1表中a列为4的这条记录。存储引擎首先从根节点(一般常驻内存)开始查找:

  • 第一个索引的第一个索引列为1,   12大于1,第二个索引的第一个索引列为56,  12小于56,于是从这俩索引的中间读到下一个节点的磁盘文件地址;
  • 从磁盘上Load第二层这个节点,通常伴随一次磁盘IO,然后在内存里去查找。查找到第二层中间那个节点的b列=12,再次通过索引中间的地址,load叶子节点;
  • 当Load叶子节点的第二个节点时,又是一次磁盘IO,比较第一个元素,b=12,c=14,d=3完全符合,于是找到该索引下的data元素即ID值,
  • 再从主键索引树上找到最终数据。

 

 

回到顶部(go to top)

参考文献

————————————————
版权声明:本文为CSDN博主「问北」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ibigboy/article/details/104571930/

 

posted on   frank_cui  阅读(1677)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
历史上的今天:
2020-09-19 Java 多线程 - 用CAS方式获取锁的,都是乐观锁么?
2020-09-19 Java多线程 - 互斥锁 vs 自旋锁、读写锁、悲观锁 vs 乐观锁、公平锁 vs 非公平锁
2020-09-19 Java多线程 - synchronized 底层实现原理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

levels of contents
点击右上角即可分享
微信分享提示