B树、B+树发展史 、区别[通俗易懂]

B树、B+树发展史 、区别[通俗易懂]顺序查找:就是从第一个元素开始,按索引顺序遍历待查找序列,直到找出给定目标或者查找失败 缺点:效率低 – 需要遍历整个待查序列 二分法查找:也称为折半法,是一种在有序数组中查找特定元素的搜

B树、B+树发展史 、区别

顺序查找:就是从第一个元素开始,按索引顺序遍历待查找序列,直到找出给定目标或者查找失败

缺点:效率低 — 需要遍历整个待查序列

二分法查找:也称为折半法,是一种在有序数组中查找特定元素的搜索算法。

  1:首先,从数组的中间元素开始搜索,如果该元素正好是目标元素,则搜索过程结束,否则执行下一步。

  2:如果目标元素大于/小于中间元素,则在数组大于/小于中间元素的那一半区域查找,然后重复步骤1的操作。

  3:如果某一步数组为空,则表示找不到目标元素

树的概念

树:连通无回路的无向图是一棵树.

根:树中的根是树的一个节点,任意节点都可以为根,根据不同问题可以选择树的一个顶点为根.

子节点&父节点:树根为0层,直接和树根相连的节点为根节点的子节点,根节点为其父节点,根节点的子节点为树的1层.对于除了根节点以外的节点u来说,直接与其相连的节点中,除了一个父节点以外的所有节点都是u的子节点,u节点的子节点的层数为u节点的层数加1.

子树:对于树中的一个节点u来说,包含其一个儿子节点以及儿子节点的所有后辈节点的树称为节点u的子树.

兄弟节点:同一父节点的子节点.

叶子节:没有子节点的节点称为叶子节点.

分支节点:除了根节点和叶子节点之外的所有节点都称为分支节点.

树高:树的总层数.

树的种类

无序树:任意子节点之间没有顺序关系,也称自由树

有序树:任意节点的子节点之间有顺序关系,如下:

二叉树:如果每个节点的儿子节点不多于两个,则称这棵树为二叉.每个父节点的子节点用左右儿子节点来加以区分,以左儿子节点为根的子树称为左子树,以右儿子节点为根的树称为右子树.

满二叉树:如果一个二叉树的任何节点或者树叶,或者恰好有两颗非空子树,则此二叉树称为满二叉树.

完全二叉树:如果一棵二叉树最多只有最下面的两次节点度数小于2,并且最下面一层的节点都集中在该层的最左边的连续位置,成称其实完全二叉树.

平衡二叉树(Balanced Binary Tree)又被称为AVL树(有别于AVL算法),且具有以下性质:它是一 棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树.

储存:链式储存。

红黑树: 在平衡二叉树稳定性的基础上,再优化一下,减少旋转次数
特性:
1、每个节点要么是红色,要么是黑色。
2、根节点必须是黑色。
3、红色节点不能连续(也即是,红色节点的孩子和父亲都不能是红色)。
4、对于每个节点,从该点至null(树尾端)的任何路径,都含有相同个数的黑色节点。

B树、B+树发展史 、区别[通俗易懂]

二叉树特点:查找速度和比较次数最小,但是磁盘IO,当数据量过大的时候,索引大小可能有几个G,不可能全都加载到内存

引出下面的树更稳

B树与B+树

B树 、B – 树都读B树。

B树与B+树区别:

B树每个节点都存储数据,所有节点组成这棵树。B+树只有叶子节点存储数据(B+数中有两个头指针:一个指向根节点,另一个指向关键字最小的叶节点),叶子节点包含了这棵树的所有数据所有的叶子结点使用链表相连,便于区间查找和遍历,所有非叶节点起到索引作用

B树中叶节点包含的关键字和其他节点包含的关键字是不重复的,B+树的索引项只包含对应子树的最大关键字和指向该子树的指针,不含有该关键字对应记录的存储地址。

B树中每个节点(非根节点)关键字个数的范围为[m/2(向上取整)-1,m-1](根节点为[1,m-1]),并且具有n个关键字的节点包含(n+1)棵子树。B+树中每个节点(非根节点)关键字个数的范围为[m/2(向上取整),m](根节点为[1,m]),具有n个关键字的节点包含(n)棵子树。

B+树中查找,无论查找是否成功,每次都是一条从根节点到叶节点的路径。

B树的优点:

b+树的中间节点不保存数据,能容纳更多节点元素

B树的每一个节点都包含key和value,因此经常访问的元素可能离根节点更近,因此访问也更迅速。

M阶B+数特点

有n棵子树的非叶子结点中含有n个关键字(b树是n-1个),这些关键字不保存数据,只用来索引,所有数据都保存在叶子节点(b树是每个关键字都保存数据)。
所有的叶子结点中包含了全部关键字的信息,及指向含这些关键字记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接(叶子节点组成一个链表)。
所有的非叶子结点可以看成是索引部分,结点中仅含其子树中的最大(或最小)关键字。
通常在b+树上有两个头指针,一个指向根结点,一个指向关键字最小的叶子结点。
同一个数字会在不同节点中重复出现,根节点的最大元素就是b+树的最大元素。

B树和B+树的共同优点

考虑磁盘IO的影响,它相对于内存来说是很慢的。数据库索引是存储在磁盘上的,当数据量大时,就不能把整个索引全部加载到内存了,只能逐一加载每一个磁盘页(对应索引树的节点)。所以我们要减少IO次数,对于树来说,IO次数就是树的高度,而“矮胖”就是b树的特征之一,m的大小取决于磁盘页的大小。

虽然查询次数比二叉树多,尤其当单一节点元素多时,但是相比磁盘IO速度,内存中的比较耗时几乎可以忽略

所以只要树的高度是够低,IO次数是足够少,就可以提升查找性能

IO:每一次读取的数据称之为一页.

B树与B+树比较:

  • 同样大小的磁盘页B+树可以容纳更多的节点元素,也就意味着B+树更矮胖,查询时IO次数更少;
  • B+树的查询必须最终是叶子节点,而B-树只要找到匹配元素即可,因此,B+树查找性能稳定,B树不稳定;
  • 范围查询简便,所有的叶子结点使用有序链表相连,便于区间查找和遍历.

B树示意图:
B树、B+树发展史 、区别[通俗易懂]

 

 

以下为 B+树示意图:

B树、B+树发展史 、区别[通俗易懂]

B树、B+树发展史 、区别[通俗易懂]

 

存储引擎: MyISAM和InnoDB

在MySQL中,最常用的两个存储引擎是MyISAM和InnoDB,它们对索引的实现方式是不同的

MyISAMdata存的是数据地址。索引是索引,数据是数据。索引放在XX.MYI文件中,数据放在XX.MYD文件中,所以也叫非聚集索引

B树、B+树发展史 、区别[通俗易懂]

 

 

InnoDB: data存的是数据本身。索引也是数据。数据和索引存在一个XX.IDB文件中,所以也叫聚集索引。

B树、B+树发展史 、区别[通俗易懂]

 

 我们的Mysql数据库用的InnoDB。

了解了数据结构再看索引,一切都不费解了,只是顺着逻辑推而已。另加两种存储引擎的区别:

1、MyISAM是非事务安全的,而InnoDB是事务安全的

2、MyISAM锁的粒度是表级的,而InnoDB支持行级锁

3、MyISAM支持全文类型索引,而InnoDB支持全文索引

4、MyISAM相对简单,效率上要优于InnoDB,小型应用可以考虑使用MyISAM

5、MyISAM表保存成文件形式,跨平台使用更加方便

6、MyISAM管理非事务表,提供高速存储和检索以及全文搜索能力,如果在应用中执行大量select操作可选择

7、InnoDB用于事务处理,具有ACID事务支持等特性,如果在应用中执行大量insert和update操作,可选择。

 

 

 

 

 

参考文献:

https://www.cnblogs.com/daguozb/p/8665506.html

https://www.cnblogs.com/Ash-ly/p/5459688.html

https://www.jianshu.com/p/f456d7c80ffb

https://blog.csdn.net/weixin_42228338/article/details/97684517

https://blog.csdn.net/zhuanzhe117/article/details/78039692

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8010.html

(0)
上一篇 2023-03-09
下一篇 2023-03-09

相关推荐

  • oracle自动生成序列号_oppoa5全局主题教程

    oracle自动生成序列号_oppoa5全局主题教程  前面我们介绍了MyCat的分库分表操作,那么同一张表中的数据会被保存在不同的数据库中,那么这就涉及到了主键维护的问题,此时肯定不能使用单个数据库中id自增的方式来处理了,这时我们就可以通过MyC…

    2022-12-16
    137
  • SqlServer性能优化,查看CPU、内存占用大的会话及SQL语句[通俗易懂]

    SqlServer性能优化,查看CPU、内存占用大的会话及SQL语句[通俗易懂]1,查看CPU占用量最高的会话及SQL语句 select spid,cmd,cpu,physical_io,memusage, (select top 1 [text] from ::fn_get_s

    2022-12-22
    138
  • 解放双手,数据库智能调参CDBTune等你来测

    解放双手,数据库智能调参CDBTune等你来测好消息,腾讯云数据库团队智能调参CDBTune产品现已进入内测阶段,欢迎数据库爱好者、使用者、开发者前来测试。 CDBTune(cloud database tune)是基于2019至2021年间腾讯

    2023-05-20
    127
  • ORACLE数据库的DBLINK问题「建议收藏」

    ORACLE数据库的DBLINK问题「建议收藏」当用户要跨本地数据库,访问另外一个数据库表中的数据时,本地数据库中必须创建了远程数据库的dblink,通过dblink本地数据库可以像访问本地数据库一样访问远程数据库表中的数据。下面讲介绍我之前项目…

    2022-12-15
    132
  • Redis集群的安装

    Redis集群的安装Redis集群的安装步骤 注意:redis的单节点安装之前已经安装好了 1.创建安装目录 在master ,node1 ,node2中分别创建 mkdir /usr/local/soft/redis-

    2023-04-22
    162
  • Spyder与Python的关系

    Spyder与Python的关系在今天的科技时代,计算机编程成为了一个火热的领域,而Python被誉为编程界的“瑞士军刀”,成为了各个领域里必不可少的编程语言之一。而对于Python开发者来说,一款高效的IDE是必不可少的,这里介绍一下Spyder这个Python IDE。

    2024-07-23
    26
  • Python中如何添加列表项

    Python中如何添加列表项在Python中,常常需要使用到列表来存储数据。同时,在程序运行中,我们也经常需要添加新的数据项到列表中,Python提供了多种方法来实现列表项的添加操作。下面将从多个方面来详细阐述Python如何添加列表项。

    2024-03-06
    72
  • mysql基础语句增删改查_mysql数据库试题

    mysql基础语句增删改查_mysql数据库试题1、数据库语言的分类
    2、DDL:数据库定义语言 data Definition language
    3、DQL:数据查询语言 data Query language
    4、DQL:数据查询语言 data

    2023-01-27
    144

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注