B树和B+树的介绍和对比,以及MySQL为何选择B+树
在计算机科学中,B树和B+树是常用的数据结构,用于在大规模数据集上进行高效的插入、删除和查找操作。它们在数据库管理系统、文件系统等许多实际应用中发挥着重要作用。本文将深入介绍B树和B+树的结构特点、实际应用方面以及它们的优缺点,并最后进行二者的对比。
B树介绍
B树是一个多路搜索树,每个节点可以存储多个关键字和对应的数据
一颗阶数为n(n>=2)的B树具有以下结构特点:
节点和关键字:
- 根节点至少有1个关键字
- 非叶子节点包含k个关键字,其中k范围ceil(n/2)-1 ≤ k ≤ n-1,并且关键字按照升序排列
- 非叶子节点具有k+1个子节点(k+1个指向子节点的指针)
- 所有叶子节点位于相同的层级,并且都是空节点或者包含数据的节点
最小度(非叶子节点的最小子节点个数):
- 最小度t,满足2 ≤ t (因为根节点必须有两个子节点,两个非空的)
- 非叶子节点满足:关键字范围(t-1) ~ (2t-1)
一棵四阶B树的结构图:
实际应用:
-
文件系统:B树常被用作文件系统的索引结构。它可以有效地管理大量的文件和目录,并支持快速的文件查找和访问。典型的例子包括Unix文件系统中的Inode索引和NTFS文件系统中的MFT(Master File Table)索引。
-
数据库系统:B树是关系数据库管理系统中常见的索引结构之一。它被广泛用于构建数据库中的索引,以加快数据的检索速度。B树的平衡性和高效性使得它适用于存储大量数据的场景,并且能够支持范围查询、插入和删除操作。
-
磁盘和存储系统:B树的结构特点使得它适用于管理存储和磁盘上的数据。B树的节点大小通常与磁盘块大小相匹配,可以减少磁盘访问次数,并提高数据的读写效率。
-
搜索引擎:B树在搜索引擎中用于构建倒排索引,加速文档的搜索和检索。倒排索引存储了词汇表和每个词汇对应的文档列表,B树使得在大规模文档集合中进行高效的关键字搜索成为可能。
B树优点:
- 高效的查找:B树是一种多路搜索树,可以在具有大量数据的情况下快速查找目标元素。它的高度相对较低,因此查找操作的时间复杂度为O(log n),其中n是元素的数量。
- 高度平衡:B树在插入和删除操作后能够自动保持平衡,使得树的高度相对稳定。这确保了各个节点之间的平衡性,避免了树的倾斜,提高了整体性能。
B树缺点:
- 结构相对复杂,实现难度较大。
- 内存占用:B树的节点通常比其他树结构的节点更大,因为它需要存储关键字和子节点的指针。
- 节点的分裂和合并操作可能导致频繁的磁盘IO操作,影响性能。
B+树介绍
B+树是在B树基础上进行了改进和优化,具有以下结构特点:
- B+树与B树的结构类似,但是所有数据都存储在叶子节点上,而非叶子节点只包含关键字范围(或称为分裂值)和指向子节点的指针。
- 非叶子节点的关键字范围与子节点一致(k = n,k为键树,n为子节点)
- 所有叶子节点使用链表连接形成有序链表,提高了范围查询的效率。
- 非叶子节点的关键字起到索引的作用,可以加速查找操作。
一颗4阶B+树结构图:
实际应用:
-
文件系统:B+树常被用于文件系统的元数据管理,如目录结构和文件索引,B+树可以快速定位和访问文件或目录,同时支持高效的范围查询和顺序访问。
-
关系型数据库(经典MySQL):B+树通常用于关系型数据库的聚集索引和辅助索引。聚集索引决定了数据的物理存储顺序,而辅助索引加快了特定字段的查询速度。
-
文件索引:B+树可以用于文件索引,特别是大规模文件存储系统中。它可以快速定位和访问文件块或数据块,提高文件系统的读写效率。
-
日志结构化存储:B+树被应用于日志结构化存储(Log-Structured Storage)中,例如用于分布式文件系统和分布式数据库系统,B+树的顺序访问性能和范围查询能力使得它适合于处理大量写入操作和高效的数据恢复。
优点:
-
高效的范围查询:B+树的叶子节点形成有序链表,使得范围查询操作非常高效。通过遍历叶子节点链表,可以快速获取范围内的数据,适用于诸如区间查询等操作。
-
顺序访问性能好:由于叶子节点形成有序链表,B+树对于顺序访问的性能较好。可以通过遍历叶子节点链表来按顺序获取数据,适用于排序、分页和顺序遍历等操作。
-
高度相对较低:B+树的节点可以存储多个关键字,因此相比于其他平衡树结构,B+树的高度相对较低。这降低了磁盘访问的次数,提高了数据的访问效率。
-
支持大规模数据集:B+树适用于大规模数据集的索引,具有良好的扩展性。它可以有效地处理大量的数据和高并发访问,适合在数据库和文件系统等场景中使用。
-
有序性:B+树的关键字在节点内部以有序方式存储,这对于范围查询、排序和范围分割等操作非常有利。
缺点:
-
写操作相对复杂:相比于其他树结构,B+树的插入和删除操作可能稍显复杂。因为插入和删除可能触发节点的分裂和合并,需要进行额外的调整操作。
-
空间开销较大:B+树的节点需要存储关键字和指针,因此在存储空间上会有一定的开销。尤其是对于小规模数据集来说,B+树可能会占用更多的内存空间。
B树与B+树的对比(区别)
-
关键字位置:在B树中,所有关键字都存储在节点中,并且叶子节点和非叶子节点具有相同的结构。而在B+树中,所有关键字都存储在叶子节点中,非叶子节点只包含关键字的范围和指向子节点的指针。
-
叶子节点结构:B树的叶子节点存储关键字和对应的数据(或指向数据的指针),而B+树的叶子节点只存储关键字和指向数据的指针。叶子节点通过指针连接形成有序链表,而非叶子节点只包含关键字范围和指向子节点的指针。
-
范围查询和顺序访问:由于B+树的叶子节点形成有序链表,B+树在范围查询和顺序访问方面具有优势。B树在这些操作上的性能相对较差,需要进行更多的节点访问。
-
高度:由于B+树的关键字全部存储在叶子节点中,非叶子节点只包含关键字的范围和指向子节点的指针,B+树的高度相对较低。而B树的高度相对较高,因为关键字存储在节点中,非叶子节点和叶子节点具有相同的结构。
经典问题:MySQL为什么采用B+树而不是B树作为索引结构?
-
范围查询性能:B+树在范围查询方面具有更好的性能。由于B+树的叶子节点形成有序链表,可以非常高效地执行范围查询操作,例如大于、小于、区间查询等。对于数据库系统来说,范围查询是非常常见的操作,因此B+树更适合作为索引结构。
-
顺序访问性能:B+树在顺序访问方面也表现较好。由于B+树的叶子节点形成有序链表,可以按顺序访问数据,例如排序、分页和顺序遍历等操作。对于一些特定的查询需求,B+树的顺序访问性能更高。
-
更低的树高度:B+树相对于B树来说,具有更低的树高度。这是因为B+树的关键字全部存储在叶子节点中,非叶子节点只包含关键字范围和指向子节点的指针。较低的树高度意味着在查询过程中需要更少的磁盘访问,提高了查询效率。
-
内存占用:B+树的节点大小比B树相对较小,可以容纳更多的节点在内存中,从而提高了缓存的效率。这对于数据库系统来说尤为重要,因为它们需要频繁地从磁盘加载节点到内存中进行查询操作。
-
适应大规模数据集:MySQL作为一种常用的关系型数据库系统,通常需要处理大规模的数据集。B+树对于大规模数据集的索引具有较好的扩展性,能够高效地处理大量的数据和高并发访问。
相关文章:
B树和B+树的介绍和对比,以及MySQL为何选择B+树
在计算机科学中,B树和B树是常用的数据结构,用于在大规模数据集上进行高效的插入、删除和查找操作。它们在数据库管理系统、文件系统等许多实际应用中发挥着重要作用。本文将深入介绍B树和B树的结构特点、实际应用方面以及它们的优缺点,并最后…...
MD5 绕过第一式:弱比较绕过
文章目录 参考环境MD5韧性脆弱性md5() 隐式类型转换字符串连接数学运算布尔判断相等运算符 科学计数法科学计数法前缀 0E 与 0e PHP8 与 PHP 其他版本下字符串转化为数值的具体规则PHP8数值字符串优化 其他版本更为详细的讲解 字符串与字符串的弱比较字符串与数值的弱比较0e215…...
红黑树是如何实现的?
文章目录 一、红黑树的概念二、红黑树的性质三、红黑树和AVL树对比四、红黑树的插入1. 红黑树的结点定义2. 父亲的颜色3. 叔叔的颜色为红色4. 叔叔不存在5. 叔叔存在且为黑6. 插入的抽象图 五、红黑树的验证1. 检查平衡2. 计算高度与旋转次数3. 验证 六、 红黑树与AVL树的比较 …...
实验室没人导该怎么办
实验室没人教该怎么办 Q: 国内top5高校研一,课题开始老板就给了一个大方向,之后怎么做实验都是自己看文献研究的,终于开始动手做实验,才发现别人根本不想管你,宁愿抱着电脑看剧也不想教你,十分焦虑,该怎么办? A: 按照大多数实验室的惯例,老板一定会指派一个小老板…...
pytest简明教程
1. 简介 pytest是一款基于Python的测试框架。与Python自带的unittest相比,pytes语法更加简洁,断言更加强大,并且在自动测试以及插件生态上比unittest都要更加强大。 1.1. 安装pytest pip install pytest1.2. pytest命名规则 pytest默认会…...
解决方案:解决https页面加载http资源报错
HTTPS页面加载HTTP资源会报错的原因是出于安全性考虑。 HTTPS(HyperText Transfer Protocol Secure)是一种通过使用SSL/TLS加密通信来保护数据传输的协议,它确保了客户端和服务器之间的安全连接。 当HTTPS页面尝试加载非加密的HTTP资源时&a…...
嵌入式开源库之libmodbus学习笔记
socat 安装sudo apt-get install socat创建终端 socat -d -d pty,b115200 pty,b115200查看终端 ls /dev/pts/ minicom 安装 sudo apt-get install minicom链接虚拟终端 sudo minicom -D /dev/pts/3以十六进制显示 minicom -D /dev/pts/1 -H设置波特率 minicom -D /dev/pts/1…...
Spring MVC 中的数据验证技术
一、前言 在Web开发中,数据验证是不可或缺的一部分。Spring MVC 框架提供了强大的数据验证支持,可以帮助我们轻松地对用户提交的数据进行验证。 二、实现 Spring MVC 使用 JSR-303 验证规范(Hibernate Validator 是其参考实现)…...
windows 修改hosts映射,可以ping通,但是无法通过http url 路径访问,出现 500 Internal Privoxy Error
问题描述 今天在学习nginx时,想在hosts配置一个nginx的域名映射,但是发现访问nginx服务的ip时可以访问通,在dos命令窗口ping配置的域名映射也可以ping通,但是一旦在浏览器通过http请求访问配置的hosts域名映射时却出现 500 Inter…...
如何将图片转为ico格式
这里主要是记录一个网站,如果你有更好的办法欢迎留言~ ico简介 ICO(Icon)是一种用于表示图标的文件格式,常用于Windows操作系统中。ICO格式的图片通常用于表示应用程序、文件夹、网站等的图标。 ICO文件可以包含多个图标&#x…...
ElasticSearch - 基于 JavaRestClient 操作索引库和文档
目录 一、RestClient操作索引库 1.1、RestClient是什么? 1.2、JavaRestClient 实现创建、删除索引库 1.2.1、前言 1.2.1、初始化 JavaRestClient 1.2.2、创建索引库 1.2.3、判断索引库是否存在 1.2.4、删除索引库 1.3、JavaRestClient 实现文档的 CRUD 1.3…...
【人脸质量评估】MagFace:一个既可以用作人脸识别,又可以用作人脸质量评估的方法
论文题目:《MagFace: A Universal Representation for Face Recognition and Quality Assessment》-CVPR2021 论文地址:https://arxiv.org/abs/2103.06627v4 代码地址:https://github.com/IrvingMeng/MagFace...
FPGA 图像缩放 千兆网 UDP 网络视频传输,基于RTL8211 PHY实现,提供工程和QT上位机源码加技术支持
目录 1、前言版本更新说明免责声明 2、相关方案推荐UDP视频传输--无缩放FPGA图像缩放方案我这里已有的以太网方案 3、设计思路框架视频源选择ADV7611 解码芯片配置及采集动态彩条跨时钟FIFO图像缩放模块详解设计框图代码框图2种插值算法的整合与选择 UDP协议栈UDP视频数据组包U…...
智能驾驶、智能家居、智能工业中的 AI 关键基础设施,半导体厂商恩智浦的角色是什么?
我们来看一条七年前的真实新闻报道,2016 年《福布斯》在报道中提到“2020 年会有 1000 万台的自动驾驶汽车”。然而 2023 年的现在,真正实现 L4 级别自动驾驶的汽车,仍然远远没有达到这个预测的数量。 另一边,数据显示,…...
APScheduler包——python tornado框架中实现定时任务
介绍: APScheduler的全称是Advanced Python Scheduler。它是一个轻量级的 Python 定时任务调度框架。APScheduler 支持三种调度任务:固定时间间隔,固定时间点(日期),Linux 下的 Crontab 命令。同时…...
BASH shell脚本篇3——字符串处理
这篇文章介绍下BASH shell中的字符串处理的相关命令。之前有介绍过shell的其它命令,请参考: BASH shell脚本篇1——基本命令 BASH shell脚本篇2——条件命令 Bash字符串也是一种数据类型,它用于表示文本而不是数字,它是一组可能…...
【SSL】用Certbot生成免费HTTPS证书
1. 实验背景 服务器:CentOS7.x 示例域名: www.example.com 域名对应的web站点目录: /usr/local/openresty/nginx/html 2. 安装docker # yum -y install yum-utils# yum-config-manager --add-repo https://download.docker.com/linux/ce…...
报错:java.sql.SQLSyntaxErrorException: Table ‘examsys.Teacher’ doesn’t exist
Linux大小写区分,导致部署项目时MySQL出现错误 问题原因:找不到Teacher这张表。因为在windows下的mysql表名不区分大小写,所以在windows下运行项目没问题。在linux中,mysql会区分大小写,所以sql语句表名用大写的就会找…...
.NET的PLC帮助类
TCP和UDP协议: TCP(传输控制协议)和UDP(用户数据报协议)是TCP/IP协议簇中的两种核心协议。它们在传输层上提供数据传输服务,但具有不同的特性和功能。 TCP协议是一种提供可靠、面向连接的字节流服务的传输协…...
Linux中nfs:failed: Operation not supported
先给出思路: 一个简单粗暴的方式:卸载重装排除未知问题,步骤如下: 一、在 Linux 上卸载 NFS 服务器,步骤: 停止 NFS 服务: sudo service nfs-kernel-server stop如果您使用的是不同的发行版&am…...
ElasticSearch映射与模板介绍
一、前言 前面有相关系列文章介绍了ES的基本概念和各种版本SDK的使用,ES现在已升级到8.5版本,有些概念和SDK用法都有很大变化,后续ES相关的文章会以8.3版本为基准介绍一些实际中应用需要掌握的概念以及一些比较实际的例子。 二、映射 ES环…...
通过 Azure 日志分析加强云安全
Microsoft Azure 云服务在安全日志存储、访问、可伸缩性、降低成本和易于部署方面提供了巨大的优势,因此在企业中很受欢迎。 Microsoft Azure 日志记录工具(如 Log360)可帮助管理 Azure 云基础结构中所有设备和应用程序(如虚拟机…...
[H5动画制作系列 ]变量,帧频,监听器等的生命周期基础测试
模式:按照上述抓图,actions层,1帧,写初始化代码,10帧写返回代码到2帧代码,2-10帧之间一直循环。1帧及10帧代码如下: 如果程序在1-10之间循环,会反复创建变量i,多个监听器等。所以,第一帧最好执行一次即可,程序在2-10帧之间一直循环。...
基于SpringBoot的服装生产管理系统的设计与实现
目录 前言 一、技术栈 二、系统功能介绍 登录界面的实现 系统主界面的实现 用户管理模块的实现 人事安排管理模块的实现 工资管理模块的实现 考勤管理模块的实现 样板管理模块的实现 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 本协力服装厂服装生…...
动态内存操作(2)
接上一篇文章http://t.csdn.cn/1ONDq,这次我们继续讲解关于动态内存的相关知识。 一、常见的动态内存错误 1.对NULL指针进行解引用操作 #include<stdio.h> #include<stdlib.h> #include<limits.h> int main() {int* p (int*)malloc(INT_MAX/4);…...
Windows-Delphi 窗口置顶
露从今夜白,月是故乡明。 1.Delphi将窗口置顶 if topHwnd <> 0 thenbeginSetWindowPos(topHwnd, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE or SWP_NOSIZE);tmr1.Enabled : True;end; 其中topHwnd是目标窗口的句柄。 2.窗口取消置顶 if topHwnd <> 0 th…...
CVE-2020-11978 Apache Airflow 命令注入漏洞分析与利用
简介 漏洞软件:Apache Airflow影响版本:< 1.10.10 环境 Vulhub 漏洞测试靶场 复现步骤 进入 /root/vulhub/airflow/CVE-2020-11978/ 目录运行以下命令启动环境 # 初始化数据库 docker compose run airflow-init # 开启服务 docker compose up -…...
面试经典算法1:DFS
一、前言 1、题目描述和代码仅供参考,如果有问题欢迎指出 2、解题代码采用acm模式(自己处理输入输出),不采用核心代码模式(只编程核心函数) 3、解题代码采用C语言(ai一键翻译任意语言ÿ…...
Windows系统利用cpolar内网穿透搭建Zblog博客网站并实现公网访问内网!
文章目录 1. 前言2. Z-blog网站搭建2.1 XAMPP环境设置2.2 Z-blog安装2.3 Z-blog网页测试2.4 Cpolar安装和注册 3. 本地网页发布3.1. Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 1. 前言 想要成为一个合格的技术宅或程序员,自己搭建网站制作网页是绕…...
SmartCode ViewerX VNC 3.11 Crack
SmartCode ViewerX VNC 查看器 ActiveX 轻松地将 VNC 查看器功能添加到您的应用程序中 SmartCode ViewerX VNC Viewer ActiveX 使开发人员可以使用一组直观的 ActiveX 属性和方法完全访问 VNC 查看器功能。借助ViewerX控件,开发人员可以轻松地为其应用程序提供屏幕共…...
wordpress不好/seo如何挖掘关键词
Android 内存溢出和内存泄漏的问题在面试中,经常有面试官会问“你知道什么是内存溢出?什么是内存泄漏?怎么避免?”通过这篇文章,你可以回答出来了。内存溢出(OOM)是指程序在申请内存时,没有足够的内存空间供…...
网站内部seo/关键词排名点击软件怎样
废话不多说,直接进入话题 Linux上Cacti的安装 1.环境需求 cacti需要 lamp 或lnmp环境。 2.cacti前置需求软件 安装Cacti前,需要php-pdo lm_sensors net-snmp php-snmp net-snmp-utils perl-Net-Daemon perl-PlRPC perl-DBI rrdtool perl-rrdtool p…...
做ppt的素材网站/进行seo网站建设
2019独角兽企业重金招聘Python工程师标准>>> mysql出现:Lock wait timeout exceeded; try restarting transaction 什么问题导致的呢?绝对是程序的问题,因为另一个线程锁住了表或者记录导致后来到请求无法完成。 如何产生的&…...
wordpress 动态背景/模板之家
给出一个二维的字母板和一个单词,寻找字母板网格中是否存在这个单词。 单词可以由按顺序的相邻单元的字母组成,其中相邻单元指的是水平或者垂直方向相邻。每个单元中的字母最多只能使用一次。 样例 给出board [ “ABCE”, “SFCS”, “ADEE” ]…...
魔客吧是什麼程序做的网站/职业技能培训班
我正在尝试用箭头键和回车键使一系列按钮可导航。在我已经很容易地实现了箭头键,但是我似乎在网上找不到如何将焦点按钮绑定到enter键的答案。具体来说,我希望能够使用向上/向下键将焦点设置为按钮,然后按enter键激活按钮。在我可以用箭头高亮…...
做网站维护怎么找客户/百度知道答题赚钱
动态内存是一个有用的功能,但在配置虚拟机和主机服务器时,必须小心谨慎。谈及承载虚拟工作负载,硬件资源对整体性能的重要性可能不如物理内存。以确保每台虚拟机都具有所需内存且不会浪费进程中的内存的方式分配内存非常重要。下面是分配供 M…...