B-树和B+树

本文介绍了B树和B+树的基本概念和特性,包括它们的节点结构、关键字数量限制以及查找性能。B树每个节点包含索引和数据,适合随机查找;B+树所有数据存储在叶子节点,利于范围查询和IO效率。B+树在数据库索引中广泛应用,因其稳定查询性能和高效范围查询能力。
摘要由CSDN通过智能技术生成

B - 树

(推荐:https://zhuanlan.zhihu.com/p/54084335)
在这里插入图片描述

首先强调一点B-树就是B树(就是B杠树),千万别读成B减树了!!!
B树和B+树其实就是从二叉树变换而来的。
特点:

  • 每个节点最多有m-1个关键字(可以存有的键值对)。
  • 根节点最少可以只有1个关键字。
  • 非根节点至少有m/2个关键字。
  • 每个节点中的关键字都按照从小到大的顺序排列,每个关键字的左子树中的所有关键字都小于它,而右子树中的所有关键字都大于它。
  • 所有叶子节点都位于同一层,或者说根节点到每个叶子节点的长度都相同。
  • 每个节点都存有索引和数据,也就是对应的key和value。

另外,我们需要注意一个概念,描述一颗B树时需要指定它的阶数,阶数表示了一个节点最多有多少个孩子节点,一般用字母m表示阶数。
B树的插入和删除,推荐连接中的比较详细。

B+树

(讲解很详细 https://zhuanlan.zhihu.com/p/54102723)
在这里插入图片描述

B+树的特征:

1.有k个子树的中间节点包含有k个元素(B树中是k-1个元素),每个元素不保存数据,只用来索引,所有数据都保存在叶子节点。

2.所有的叶子结点中包含了全部元素的信息,及指向含这些元素记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。

3.所有的中间节点元素都同时存在于子节点,在子节点元素中是最大(或最小)元素。

B+树的优势:

1.单一节点存储更多的元素,使得查询的IO次数更少。

2.所有查询都要查找到叶子节点,查询性能稳定。

3.所有叶子节点形成有序链表,便于范围查询。

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
B树、B-B+树都是一种平衡的多路查找,用于在磁盘等外部存储设备中进行高效的查找操作。 B树是一种平衡的多路查找,每个节点可以存储多个数据,并且每个节点可以有多个子节点B树的每个节点存储了一定的范围区间,这样可以加快搜索速度。例如,对于1~100的索引值,B树可以将其划分为多个区间,从而一次性排除大部分数据,使搜索更加高效。 B-B树的一种变体,它的每个节点可以存放多个数据和子节点,并且相邻的叶节点之间可以相互连接,这样可以增加区间访问性能,适用于范围查询等操作。 B+树也是B树的一种变体,与B树和B-不同的是,B+树的叶子节点之间互相连接,而非叶子节点只存储索引信息,数据只存在于叶子节点中。这样可以提高区间查询的性能,并且也适用于范围查询等操作。 总结来说,B树、B-B+树都是一种平衡的多路查找,用于在磁盘等外部存储设备中进行高效的查找操作。它们的区别在于节点的存储方式和叶子节点的连接方式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [B-B树B+树](https://blog.csdn.net/weixin_42386551/article/details/117604839)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [B-B+树的区别](https://blog.csdn.net/liuyuan1999/article/details/127382525)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值