每日学习一个数据结构-B+树

devtools/2024/9/22 23:46:11/

文章目录

    • 什么是B+树
      • 示意图
      • B+树的基本特点
      • B+树的优点
      • B+树的应用场
    • B+树分裂和合并的机制
      • 节点分裂
      • 节点合并
      • 注意事项

什么是B+树

B+树是一种自平衡的树数据结构,广泛应用于数据库和操作系统的索引结构中,特别是在MySQL的InnoDB存储引擎中。它通过保持数据排序,使得搜索、插入、删除等操作都能在对数时间内完成。以下是B+树的相关信息:

示意图

B+树示意图

B+树的基本特点

  • 所有值都出现在叶子节点:内部节点不存储数据,只存储键值,用于索引。
  • 叶子节点之间互相链接:叶子节点通过指针相互链接,方便范围查询。
  • 数据按关键字排序:叶子节点中的数据按照关键字大小排序,内部节点中的关键字也按大小排序。
  • 分支因子(M):每个内部节点可以有多个子节点,分支因子M决定了节点最多能存储的键值数。
  • 节点类型:内部节点包含键值及指向子节点的指针,不包含数据记录;叶子节点包含全部的数据记录。

B+树的优点

  • 高效的范围查询:由于叶子节点形成有序链表,B+树非常适合进行范围查询,只需遍历相应部分的链表即可。
  • 较低的树高度:B+树的高度相对较低,可以减少磁盘I/O操作,从而提高查询效率。
  • 节点分裂和合并操作相对较少:这减少了索引维护的开销。

B+树的应用场

B+树主要应用于数据库索引和文件系统的索引结构中,特别是在需要高效范围查询和大量数据存储的场景中表现出色。

B+树分裂和合并的机制

B+树节点分裂和合并的机制是其自平衡特性的关键部分,确保了树的高度保持在较小的范围内,从而优化了磁盘I/O操作和查询效率。以下是B+树节点分裂和合并的详细机制:

节点分裂

当一个节点中的关键字数量超过其最大容量(通常是分支因子M-1)时,该节点需要进行分裂。以下是分裂的步骤:

  1. 确定分裂点:选择节点中间的关键字作为分裂点。对于内部节点,分裂点通常是第⌈M/2⌉个关键字;对于叶子节点,分裂点通常是第⌈(M-1)/2⌉个关键字。
  2. 创建新节点:创建一个新的节点,并将原节点中分裂点右侧的关键字和对应的子节点(对于内部节点)或数据记录(对于叶子节点)移动到新节点中。
  3. 更新父节点:将分裂点的关键字插入到父节点中,并更新父节点中的指针,使其指向新创建的节点。如果父节点也满了,则递归地对父节点进行分裂。
  4. 调整指针:如果分裂发生在根节点,可能需要创建一个新的根节点,并将原来的根节点作为其子节点。

节点合并

当一个节点中的关键字数量低于其最小容量(通常是⌈M/2⌉-1)时,该节点可能需要合并。以下是合并的步骤:

  1. 确定合并节点:选择一个相邻的兄弟节点进行合并。通常选择关键字数量较多的兄弟节点。
  2. 移动关键字:将父节点中的一个关键字及其对应的子节点(对于内部节点)或数据记录(对于叶子节点)移动到当前节点中。
  3. 删除父节点中的关键字:从父节点中删除移动的关键字,并更新父节点中的指针。
  4. 删除空节点:如果合并后父节点中的关键字数量低于最小容量,递归地对父节点进行合并操作。
  5. 调整树结构:如果合并导致根节点为空,则删除根节点,并将新的根节点设置为原来的子节点。

注意事项

  • 平衡性:分裂和合并操作确保了B+树的平衡性,使得树的高度保持在较小的范围内。
  • 磁盘I/O优化:通过减少树的高度,B增强的树优化了磁盘I套操作,从而提高了查询效率。
  • 复杂性:虽然分裂和合并操作确保了树的平衡性,但它们也增加了插入和删除操作的复杂性。
    通过这些机制,B+树能够在插入和删除操作后保持平衡,确保高效的查询性能。

http://www.ppmy.cn/devtools/115697.html

相关文章

dbt seed 命令及应用示例

DBT-core是一个命令行工具,它使数据分析师和工程师能够更有效地转换仓库中的数据。dbt的一个强大特性是seed命令,它可以将CSV文件(称为“seed”)加载到数据仓库中。本教程将带你完成使用dbt seed命令的过程。 在dbt中,seed是可以加载到数据仓…

Linux自主学习篇

用户及权限管理 sudo 是 "superuser do" 的缩写,是一个在类 Unix 操作系统(如 Linux 和 macOS)中使用的命令。它允许普通用户以超级用户(root 用户)的身份执行命令,从而获得更高的权限。 useradd…

JVM垃圾回收算法

JVM垃圾回收算法是Java虚拟机中自动管理内存的关键机制,它通过智能识别和回收无用对象,有效防止内存泄露,提升系统性能,是Java语言高效、稳定运行的基石。让我们一同探索这一神奇算法,感受它如何为Java世界注入活力&am…

『功能项目』QFrameWork道具栏物品生成【64】

我们打开上一篇63QFrameWork框架重构OnGUI的项目, OnGUI优点: 简单易用:OnGUI是基于代码的UI系统,对于简单的调试界面或者小型项目来说,可以快速实现UI需求。即时更新:OnGUI的UI元素是即时更新的&#xff…

Qt 窗口事件机制

在 Qt 开发中,窗口的关闭、隐藏、显示等事件是常见且重要的功能。不同的事件触发条件、处理方式不同,了解和掌握这些事件有助于我们更好地控制窗口行为。本文将详细讲解这些事件的使用方法,并通过代码实例来展示其应用。 1. done(int r) — 关…

TryHackMe 第3天 | Pre Security (二)

该学习路径讲解了网络安全入门的必备技术知识,比如计算机网络、网络协议、Linux命令、Windows设置等内容。上一篇中简短介绍了计算机网络相关的知识,本篇博客将记录 网络协议 部分。 How the web works? DNS in detail DNS (Domain name system&…

宠物空气净化器该怎么选?希喂、352、霍尼韦尔哪款对吸附浮毛有效

明明我都成年很久了,我爸妈还把我当小孩一样,我干什么前都要和他们说一声。前段时间去朋友家玩,本来对宠物无感的我一下子就被她家可爱的猫咪萌化了。猫咪好可爱呀,毛茸茸的摸起来很舒服,眨巴的大眼睛看着你真的心软软…

SpringCloud的学习(二),Consul服务注册与发现、分布式配置,以及 服务调用和负载均衡

介绍 Consul 是一套开源的分布式服务发现和配置管理系统,由 HashiCorp 公司用 Go 语言开发。 提供了微服务系统中的服务治理、配置中心、控制总线等功能。这些功能中的每一个都可以根据需要单独使用,也可以一起使用以构建全方位的服务网格,…