当前位置: 首页 > news >正文

B树与B+树的区别

B树和B+树都是用于数据库和文件系统的平衡树数据结构,但它们有一些显著的区别:

节点结构:

B树:每个节点存储数据和指向子节点的指针。叶子节点也包含数据。
B+树:内部节点只存储索引值,不存储实际数据。所有实际数据都存储在叶子节点中。
数据访问:

B树:数据可以在任何节点(内部节点或叶子节点)中找到。
B+树:所有数据都在叶子节点,内部节点只起到索引的作用。因此,数据的查找只能在叶子节点完成。
叶子节点链表:

B树:叶子节点之间没有特别的链接。
B+树:所有叶子节点通过链表相互链接,这使得范围查询(如范围扫描)更加高效。
树的高度:

B树:由于数据分布在所有节点上,树的高度可能会比 B+树略高。
B+树:所有数据都集中在叶子节点,内部节点只存储索引,因此树的高度通常较低。
磁盘读写效率:

B树:因为每个节点都存储数据和索引,磁盘读写可能涉及到更多的节点。
B+树:由于内部节点只有索引而无数据,可以在相同的磁盘块中存储更多的索引,提高了读写效率。叶子节点链表也使得范围查询和顺序访问更高效。
总结来说,B+树在数据库系统中更为常用,因为它在范围查询和顺序访问上具有显著的优势。

InnoDB 存储引擎使用 B+树结构来管理表的主键索引和辅助索引。

以下是 MySQL 使用 B+树的几个关键点:

主键索引:

InnoDB 使用聚集索引(Clustered Index),主键索引就是 B+树结构。叶子节点包含了行的全部数据。
辅助索引:

辅助索引(Secondary Index)也是 B+树结构,但叶子节点存储的是主键的值而不是行的全部数据。通过辅助索引找到主键后,再通过主键索引找到完整的行数据。
这种 B+树结构在 MySQL 中广泛应用,原因包括:

高效的范围查询:由于叶子节点按顺序链接,可以快速进行范围扫描。
稳定的树高度:B+树能保持较低的树高度,减少磁盘 I/O 操作,提高查询速度。
顺序存储:叶子节点按顺序排列,适合顺序读写操作,提高磁盘利用率。
因此,MySQL 中使用 B+树来实现其高效的索引机制。

相关文章:

  • 中间件的理解
  • 数据建模标准-关系建模
  • Airtest的控制手机滑动位置偏差修正方法总结
  • yearrecord——一个类似痕迹墙的React数据展示组件
  • 鸿蒙架构之AOP
  • WordPress 主题技巧:给文章页增加“谁来过”模块。
  • 处理uniapp刷新后,点击返回按钮跳转到登录页的问题
  • 手机数据恢复篇:如何从 Android 设备内恢复数据
  • 【leetcode】 字符串相乘(大数相乘、相加)
  • STM32的TIM1之PWM互补输出_死区时间和刹车配置
  • 内容安全(深度行为检测技术、IPS、AV、入侵检测方法)
  • arcgis怎么选取某个指定区域地方的数据,比如从全国乡镇数据选取长沙市乡镇数据
  • Blackbox AI:你的智能编程伙伴
  • SQL概述及其规则与规范
  • 【BUG】已解决:NOAUTH Authentication required
  • 【译】JS基础算法脚本:字符串结尾
  • CSS相对定位
  • dva中组件的懒加载
  • EOS是什么
  • ES6 学习笔记(一)let,const和解构赋值
  • Hibernate最全面试题
  • idea + plantuml 画流程图
  • Java读取Properties文件的六种方法
  • js继承的实现方法
  • KMP算法及优化
  • Python连接Oracle
  • Redis 中的布隆过滤器
  • SQLServer之创建数据库快照
  • vue从创建到完整的饿了么(11)组件的使用(svg图标及watch的简单使用)
  • Vue小说阅读器(仿追书神器)
  • 对象管理器(defineProperty)学习笔记
  • 飞驰在Mesos的涡轮引擎上
  • 驱动程序原理
  • 如何在GitHub上创建个人博客
  • 学习JavaScript数据结构与算法 — 树
  • ​业务双活的数据切换思路设计(下)
  • ​油烟净化器电源安全,保障健康餐饮生活
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • #if 1...#endif
  • $LayoutParams cannot be cast to android.widget.RelativeLayout$LayoutParams
  • (14)Hive调优——合并小文件
  • (2)nginx 安装、启停
  • (3)nginx 配置(nginx.conf)
  • (cos^2 X)的定积分,求积分 ∫sin^2(x) dx
  • (c语言)strcpy函数用法
  • (el-Transfer)操作(不使用 ts):Element-plus 中 Select 组件动态设置 options 值需求的解决过程
  • (poj1.2.1)1970(筛选法模拟)
  • (笔试题)合法字符串
  • (二)Kafka离线安装 - Zookeeper下载及安装
  • (二刷)代码随想录第16天|104.二叉树的最大深度 559.n叉树的最大深度● 111.二叉树的最小深度● 222.完全二叉树的节点个数
  • (一)eclipse Dynamic web project 工程目录以及文件路径问题
  • (转)http-server应用
  • (转)PlayerPrefs在Windows下存到哪里去了?
  • .NET BackgroundWorker
  • .NET Compact Framework 3.5 支持 WCF 的子集