广告
返回顶部
首页 > 资讯 > 数据库 >MySQL B-tree与B+tree索引数据结构剖析
  • 895
分享到

MySQL B-tree与B+tree索引数据结构剖析

MySQL B-treeMySQL B+treeMySQL索引数据结构剖析 2022-08-22 10:08:08 895人浏览 安东尼
摘要

目录一、产生的背景1.1 进化要求二、B-tree2.1 B-tree特性三、B+tree3.1 B+tree特性四、结论一、产生的背景 二叉查找树的查找时间复杂度是O(logN),整体的查询效率已经足够高了,那么为什么

一、产生的背景

二叉查找树的查找时间复杂度是O(logN),整体的查询效率已经足够高了,那么为什么还会有B树和B+树的进化演进呢? 主要的原因是:二叉树可能会退化成一个线性树,造成磁盘io次数增高的问题,当有大量的数据存储的时候,二叉查找树查询不能将所有的数据加载到内存中,只能逐一加载磁盘页,每个磁盘对应树的节点,造成大量的磁盘IO操作(最坏的情况IO次数为树的高度),平衡二叉树由于树深度过大而造成磁盘IO读写过于频繁,进而导致效率低下。所以,为了减少磁的IO的次数,必须降低树的深度,将瘦高的树变得矮胖

1.1 进化要求

  • 每个结点能存储多个元素
  • 摒弃二叉树结构,采用多叉树

二、B-tree

B-Tree是一种多叉的平衡搜索树(并不一定是二叉的),以一个三阶B-tree为例子来分析,每个储存块都包含:关键字和指向孩子结点的指针,最多有M个孩子,M的大小主要取决于每个存储块的容量和数据库的配置M表示M阶数的意思。

image.png

2.1 B-tree特性

  • 根节点至少包括两个孩子,范围是[2,M];
  • 树中每个节点最多包含M阶数个孩子(M是阶数,3阶,即:每个节点最多包含3个孩子);
  • 除了根节点和叶子结点以外,其他每个节点至少有ceil(M/2)个孩子节点,ceil是取上限函数(M是阶数,3阶,即:每个节点至少有2个孩子);
  • 所有的叶子结点都位于同一层。

假设每个非叶子节点包含n个关键字信息,其中:

  • Ki(i=1,2..,n)为关键字,且关键字按顺序升序排序K(i-1)< Ki
  • 关键字的个数n必须满足:[ceil(m/2)-1]<=n<=m-1(非叶子结点的关键字 = 指向孩子的指针个数-1);
  • 非叶子结点的指针:P[1],P[2],...,P[M];其中P[1]指向关键字小于K[1]的子树(即:3和5均小于8),P[M]指向关键字大于K[M-1]的子树(即:13和15均大于12),其他P[i]指向关键字属于(K[i-1],K[i])的子树,是开区间(即:9和10都处于8-12区间);

假设需要查询数据15,查询步骤:

  • 首先从根部开始找,15<17,往左边P1找,P1指向的子树关键字为8和12;
  • 由于15比8和12都大,因此会找到P3;
  • P3指向了13和15,13<15,最终找到15;
  • 查找的时间复杂度为O(logN)。

三、B+tree

image.png

3.1 B+tree特性

B+树是B树的变体,其定义基本上与B树相同,除了:

  • 非叶子结点的子树指针与关键字的个数相同;
  • 非叶子结点的子树指针P[i],指向关键字值 [K[i],K[i+1])的子树,左闭右开区间
  • 非叶子结点仅用于索引,数据都保存在叶子结点中;
  • 所有的叶子结点均有一个链指针指向下一个叶子结点;
  • B+树非叶子结点仅用来存放索引,能存储更多的关键字,使得B+树相对于B树来说更矮壮,能存储更多数据。
  • 所有的数据都存储在叶子结点。

四、结论

B+tree相比B-tree更适合用来存储索引,原因如下:

  • B+树的磁盘读写代价更低,B+树内部节点不存放数据,只存放索引信息,因此其内部节点相对B-tree会更小,所以同一个盘快就能存储更多的关键字,一次性读入内存中需要查找的关键字也就越多,因此IO次数也就越低。
  • B+树的查询效率更加稳定,由于B+树内部节点并不是指向文件内容的节点,而只是叶子节点关键字的索引,索引任何一个数据的查询都必须是:任何关键字查询都是从根节点到叶子节点的查询路线,因此每个数据的查询效率都是稳定一致的
  • B+树跟有利于对数据的扫描,B-tree在解决磁盘IO性能同时并没有解决元素遍历效率低下问题,而B+树只需要遍历叶子节点就可以实现对所有关键字的扫描,所有对数据库频繁的范围查询是有着更高的查询性能。

到此这篇关于Mysql B-tree与B+tree索引数据结构剖析的文章就介绍到这了,更多相关mysql B-tree与B+tree内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL B-tree与B+tree索引数据结构剖析

本文链接: https://www.lsjlt.com/news/33790.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL B-tree与B+tree索引数据结构剖析
    目录一、产生的背景1.1 进化要求二、B-tree2.1 B-tree特性三、B+tree3.1 B+tree特性四、结论一、产生的背景 二叉查找树的查找时间复杂度是O(logN),整体的查询效率已经足够高了,那么为什么...
    99+
    2022-08-22
    MySQL B-tree MySQL B+tree MySQL索引数据结构剖析
  • 浅析MysQL B-Tree 索引
    B-Tree 索引 不同的存储引擎也可能使用不同的存储结构,i如,NDB集群存储引擎内部实现使用了T-Tree结构存储这种索引,即使其名字是BTREE;InnoDB使用的是B+Tree。 B-Tree通常一位这所有...
    99+
    2022-05-22
    MysQL B-Tree 索引 MysQL B-Tree MysQL 索引
  • Go语言中的红黑树、B Tree、B+Tree等基本数据结构
    Go语言中的红黑树、B树和B+树是基本的数据结构,可用于实现高效的查找、插入和删除操作。1. 红黑树(Red-Black Tree)...
    99+
    2023-10-12
    Go语言
  • Mysql 索引 BTree 与 B+Tree 的区别(面试)
    目录前言BTree 基本概念B+Tree 的特点查找过程的区别B+Tree索引 如何提高索引的查询性能 ?前言 ​ 说起面试,很多同学都经历过,但是 面试中 可能会遇到各种问题,mysql 的问题 也是非常多,最近我也经...
    99+
    2022-09-27
  • Mysql 索引 BTree 与 B+Tree 的区别(面试)
    目录前言BTree 基本概念B+Tree 的特点查找过程的区别B+Tree索引 如何提高索引的查询性能 ?前言 ​ 说起面试,很多同学都经历过,但是 面试中 可能会遇到各种问题,My...
    99+
    2022-11-13
  • MySQL中的B-Tree引索与Hash引索有区别吗
    MySQL中的B-Tree引索与Hash引索有区别吗?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。MySQL中B-Tree引索...
    99+
    2022-10-18
  • MySQL进阶篇(02):索引体系划分,B-Tree结构说明
    本文源码:GitHub·点这里 || GitEE·点这里 一、索引简介 1、基本概念 首先要明确索引是什么:索引是一种数据结构,数据结构是计算机存储、组织数据的方式,是指相互之间存在一种或多种特定关系的数据元素的集合,例如:链表...
    99+
    2018-11-14
    MySQL进阶篇(02):索引体系划分,B-Tree结构说明
  • PostgreSQL数据库B-Tree索引的物理存储结构是怎样的
    这篇文章主要讲解了“PostgreSQL数据库B-Tree索引的物理存储结构是怎样的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PostgreSQL数据库...
    99+
    2022-10-19
  • Oracle中B-Tree、Bitmap和函数索引使用案例总结
    目录 一、索引简介 1、索引是一个独立的数据库对象,和数据表table一样。在Oracle中,数据库对象object都是通过段segment结构表示。我们在数据字典dba_seg...
    99+
    2022-10-18
  • MySQL索引的数据结构-B+树介绍
    1.聚集索引和辅助索引 在数据库中,B+树的高度一般都在24层,这也就是说查找某一个键值的行记录时最多只需要2到4次IO,这倒不错。因为当前一般的机械硬盘每秒至少可以做100次IO,24次的IO意味着查询时间只需要0.02~0.0...
    99+
    2017-02-08
    MySQL索引的数据结构-B+树介绍
  • MySQL中InnoDB索引数据结构(B+树)详解
    mysql的innodb的索引的B+树逐步讲解 B树B+树B树和B+树的不同点聚集索引 VS 非聚集索引总结(面试题)1.为什么不使用二叉查找树?2.为什么不使用平衡二叉树?3.为什么不使用B树?4.为什么MySQL选择B+树做索引...
    99+
    2023-08-17
    b树 数据结构 mysql 数据库
  • 浅析MySQL索引结构采用B+树的问题
    目录1、B树和B+树2、原因分析3、总结一位6年经验的小伙伴去字节面试的时候被问到这样一个问题,为什么mysql索引结构要采用B+树?这位小伙伴从来就没有思考过这个问题。只因为现在都这么卷,后面还特意查了很多资料,他也希...
    99+
    2022-06-21
    mysql 索引B+树 MySQL索引结构
  • mysql索引数据结构要用B+树的原因是什么
    这篇文章主要讲解了“mysql索引数据结构要用B+树的原因是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql索引数据结构要用B+树的原因是什么”吧!1. Hash表?No因考虑到...
    99+
    2023-06-30
  • 一文了解mysql索引的数据结构为什么要用B+树
    目录1. Hash表?No2. 二叉查找树(BST)?No3. 红黑树?No4. 平衡二叉树(AVL)?差那么二点意思5. B-tree(B-树也称B树)?差那么一点意思6. B+树...
    99+
    2022-11-13
  • 深入解析MySQL索引数据结构
    目录概述索引数据结构 二叉树 红黑树 B-Tree B+Tree Hash 索引 InnoDB 索引实现(聚集) 索引文件和数据文件是分离的(非聚集) 聚集索引和非聚集索引 联合/复...
    99+
    2022-11-12
  • MySQL 执行计划explain与索引数据结构推演过程是什么
    了解MySQL 执行计划explain与索引数据结构推演过程是什么?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!先建好数据...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作