数据库使用B+树的原因

减少磁盘 I/O 次数,提高查询效率

  • 节点存储容量大 :B + 树的非叶子节点存储索引信息,不存储实际数据(数据都存储在叶子节点),所以相同空间大小的节点,B + 树可以存储更多的索引关键字。
  • 范围查询高效 :B + 树的叶子节点之间通过指针相互连接 ,形成了一个有序的链表。在进行范围查询时,只需要找到范围的起始位置,然后沿着叶子节点的链表顺序遍历即可,无需像 B 树那样在树的不同层级中反复查找,提高了范围查询的效率。

数据插入和删除操作效率较高

  • 节点分裂和合并代价小 :B + 树在插入和删除数据时,对树的结构调整相对较少。当插入数据导致节点关键字数量超过上限时,B + 树只需将节点分裂成两个,并将中间关键字提升到父节点;删除数据导致节点关键字数量不足时,可以与相邻节点合并。这种操作主要集中在叶子节点层,对树的上层结构影响较小,维护树的平衡相对容易,操作的代价也相对较小。
  • 顺序插入性能好 :数据库中的数据通常是批量插入的,B + 树的叶子节点之间的链表结构使得顺序插入数据非常高效。新插入的数据可以直接添加到叶子节点的链表末尾,不需要频繁地调整树的结构,大大提高了数据插入的速度。

数据存储和缓存利用率高

  • 数据存储紧凑 :B + 树将所有的数据存储在叶子节点,并且叶子节点之间通过链表连接,使得数据在磁盘上的存储更加紧凑。这样在读取数据时,可以一次性读取更多连续的数据块,充分利用磁盘的预读功能,提高数据的读取速度。
  • 缓存命中率高 :数据库系统会使用缓存来存储经常访问的数据,以减少对磁盘的访问。B + 树的结构使得相邻的数据在磁盘上的物理位置也相邻 ,当访问一个叶子节点的数据时,与其相邻的叶子节点数据也很可能被一起加载到缓存中,**提高了缓存的命中率,**进一步加快了后续的查询速度。

支持高效的排序和遍历操作

  • 排序方便:B + 树的叶子节点本身就是按照关键字的大小顺序排列的,所以对于需要对数据进行排序的操作,无需额外的排序算法,直接遍历叶子节点链表即可得到有序的数据。
  • 全表遍历高效:如果需要对整个数据库表进行遍历操作,B + 树只需从根节点找到最小的叶子节点,然后沿着叶子节点的链表依次访问即可,操作简单高效。
相关推荐
刘马想放假2 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠3 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦10 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠11 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾11 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82111 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q11 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒11 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记11 天前
单项不带头不循环链表
数据结构·链表
小糯米60111 天前
JS 数组
数据结构·算法·排序算法