索引的底层数据结构、B+树的结构、为什么InnoDB使用B+树而不是B树呢
创作时间:
作者:
@小白创作中心
索引的底层数据结构、B+树的结构、为什么InnoDB使用B+树而不是B树呢
引用
CSDN
1.
https://m.blog.csdn.net/qq_73301411/article/details/145411692
在数据库系统中,索引是提高查询效率的关键数据结构。本文将深入探讨MySQL中常用的索引数据结构,特别是B+树的结构特点及其在InnoDB存储引擎中的应用。
索引的底层数据结构
MySQL中常用的是Hash索引和B+树索引
Hash索引:基于哈希表实现的,查找速度非常快,但是由于哈希表的特性,不支持范围查找和排序,在MySQL中支持的哈希索引是自适应的,不能手动创建
B+树的结构
B+树 是一种高效的多路平衡树,适合磁盘存储和范围查询。它的结构特点包括数据集中在叶子节点、叶子节点连接成链表、内部节点仅存储键值和指针。在数据库和文件系统中,B+树 被广泛应用于索引和数据存储,具有查询性能稳定、适合高并发等优势。
如图:B+树具有以下特点:
- 只有叶子结点才存放数据,中间节点都是用来存放目录项作为索引
- 非叶子节点分为不同层次,通过分层来降低每一层的搜索量
B+树的搜索策略:
- 从根节点开始,通过二分法快速定位到符合页内范围包含查询值的页,在中间结点中继续根据二分法来寻找符合页内范围复合查询值的页,接着在叶子节点中通过槽查找记录使用二分法快速定位要查询的记录在哪个槽,找到槽后再遍历槽中所有的记录,找到寻找的分组。
为什么InnoDB使用B+树而不是B树呢
B-Tree:
- 每个节点既存储数据也存储子节点的指针
- 数据分布在所有的节点中,包括内部节点和叶子节点
- 查找时可能会直接在内部节点中就能找到数据不需要遍历到叶子节点
B+Tree:
- 只有叶子结点存储数据,内部节点仅存储键值和子节点的指针
- 所有叶子节点通过指针连接成一个有序链表
- 查找时必须遍历到叶子节点才能获取数据
B+Tree的优势:
更适合磁盘I/O:
- 因为B+树的内部节点不存储数据只存储键值和指针,所以每个节点可以存储更多的键值,从而降低树的高度,树的高度越低磁盘I/O次数越少,查询性能越高(索引数据量很大,一定是存储在磁盘中的,每访问一个节点就会进行一次磁盘IO操作,所以树的高度越低,一次查询的期望IO次数就越少,效率就越高)
- B+树的叶子节点通过指针连接成链表,更适合范围查询如(BETWEEN,>,<等操作),而树的范围查询需要在不同层级的节点之间跳转,效率较低
更适合数据库场景:
- 数据集中在叶子节点上,查询时都需要遍历到叶子节点,这使得查询性能更稳定。B树的数据可能分布在内部节点和叶子结点,查询性能不稳定
- 数据库查询中经常需要使用范围查询,B+树的叶子节点链表结构非常适合这种场景,而B树需要多次遍历内部节点
更适合并发控制:
- 在并发场景下,B+树的叶子节点链表可以更容易地支持范围查询和顺序访问
- 而B树的结构在并发访问时可能需要更多的锁机制(数据分布在内部节点和叶子节点。节点分裂与合并涉及多个节点。锁的粒度较大,容易导致锁冲突)
B+树在InnoDB中的具体应用:
主键索引(聚簇索引):
InnoDB使用B+树实现主键索引,叶子节点存储完整的数据行
这种设计是的通过主键查询数据时可以直接获取数据,不需要回表
二级索引(非聚簇索引):
InnoDB的二级索引也是B+树,但是叶子节点存储的是主键值,通过二级索引查询时,先获取主键值再通过主键索引查找数据(回表)
热门推荐
超导磁共振成像的技术创新与应用前景探讨
《疯狂的麦克斯:狂暴女神》:够狠够疯的废土之旅
文化遗产保护与时代挑战——中国古迹遗址保护协会学术研讨会精彩发言集锦
怎样选择合适的高空作业平台
情绪管理与压力管理策略
游戏中的8名最佳女刺客,你知道都有谁吗?
哈希算法如何验证
告别摆拍!10个小建议让你拍出最真切的婚礼瞬间
跆拳道护具的重要性:如何选择适合的护具
农民自愿永久退出土地,每亩补偿10万?须具备3大条件!
殷新主任:湿疹长在不同位置,代表不同病因?详解4种湿疹的表现
如何在爱情中保持互相尊重与理解的五个秘诀
如果舌头呈现出这几种颜色,你可能是病了
开发商五证是什么?如何判断房屋合法性?
蓝莓的禁忌
2024年度中国教育新闻网青少年阅读50本图书发布
孙权与吕蒙:君臣兼师生的深厚关系
全球港口拥堵,上海港面临三年来最大挑战
收藏!全身各部位关节活动度测量大全,附图
温病十大常用方剂
这8个时间段不宜洗澡,容易惹“病”上身
奶酪完全指南:从制作工艺到选购技巧
买车险时,为什么都会被推荐驾乘险?到底有没有用?
食品安全检测员是干嘛的?怎么拿证?前景怎么样?
英国英语学专业研究生课程详解:专业方向、申请条件与职业前景
小案件大道理|邻里因地起纷争,相邻关系纠纷该如何化解?
【王者荣耀】嫦娥:仙姿飘逸的月宫仙子,皮肤鉴赏、玩法详解与全面攻略
内存和硬盘的区别
龙行龘龘!温州江心屿与龙的故事竟有这么多,你知道几个?
泰国VS马来西亚:收入与消费大揭秘,哪个国家更适合你?