赞
踩
简介
主要针对B树和B+树的插入,删除操作进行解析
注
仅是自己的理解,有不对的地方还请大佬指正
1.1.B树的定义
B树也称B-树,它是一颗多路平衡查找树。我们描述一颗B树时需要指定它的阶数,阶数表示了一个结点最多有多少个孩子结点,一般用字母m表示阶数。当m取2时,就是我们常见的二叉搜索树。
1.2:一颗m阶的B树定义如下:
上图就是一颗4阶的B树。在实际应用中的B树的阶数m都非常大(通常大于100),所以即使存储大量的数据,B树的高度仍然比较小。每个结点中存储了关键字(key)和关键字对应的数据(data),以及孩子结点的指针。我们将一个key和其对应的data称为一个记录。但为了方便描述,除非特别说明,后续文中就用key来代替(key, value)键值对这个整体。在数据库中我们将B树(和B+树)作为索引结构,可以加快查询速速,此时B树中的key就表示键,而data表示了这个键对应的条目在硬盘上的逻辑地址。
1.3:B树的插入操作
插入操作就是插入一条记录,即(key,value)的键值对。如果B树中已经存在需要插入的键值对,则用需要插入的value替代旧的value。若B树不存在这个key,则一定是在叶子结点中进行插入操作。
下面以5阶B树为例,介绍B树的插入操作,在5阶B树中,结点最多有4个key,最少有2个key
在实现B树的代码中,为了使代码编写更加容易,我们可以将节点中存储记录的数组长度定义为m而非m-1,这样方便底层节点由于分裂向上层插入一个记录时,上层有多余的位置存储这个记录。同时,每个节点还可以存储他的父节点的引用,这样不必编写递归程序。
一般来说,对于确定的m和确定类型的记录,结点大小是固定的,无论它实际存储了多少个记录。但是分配固定结点大小的方法会存在浪费的情况,比如key为28,29所在的结点,还有2个key的位置没有使用,但是已经不可能继续在插入任何值了,因为这个结点的前序key是27,后继key是30,所有整数值都用完了。所以如果记录先按key的大小排好序,再插入到B树中,结点的使用率就会很低,最差情况下使用率仅为50%。
1.4:B树的删除操作
删除操作是指,根据key删除记录,如果B树中的记录中不存在对应key的记录,则删除失败
下面以5阶B树为例,介绍B树的删除操作,5阶B树中,结点最多有4个key,最少有2个key
2.1: B+树的定义
各种资料上B+树的定义各有不同,一种定义方式是关键字个数和孩子结点个数相同。这里我们采取维基百科上所定义的方式,即关键字个数比孩子结点个数小1,这种方式是和B树基本等价的。上图就是一颗阶数为4的B+树。
2.1:除此之外B+树还有以下的要求
2.2:B+树的插入操作
下面是一颗5阶B树的插入过程,5阶B数的结点最少2个key,最多4个key。
2.3:B+树的删除操作
如果叶子结点中没有相应的key,则删除失败。否则执行下面的步骤
下面是一颗5阶B树的删除过程,5阶B数的结点最少2个key,最多4个key。
在单元查询的时候,B+树会自定向下逐层查找,最终找到匹配的叶子节点。例如我们查找3 。
而B+树中间节点没有Data数据,所以同样大小的磁盘页可以容纳更多的节点元素。所以数据量相同的情况下,B+树比B树更加“矮胖“,因此使用的IO查询次数更少。
参考:https://www.jianshu.com/p/71700a464e97
参考:https://blog.csdn.net/Fmuma/article/details/80287924
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。