Mysql 索引 BTree 与 B+Tree 的区别(面试)

 更新时间:2022年09月27日 09:37:42   作者:阿常呓语  
这篇文章主要介绍了Mysql索引BTree与B+Tree的区别,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

前言

​ 说起面试,很多同学都经历过,但是 面试中 可能会遇到各种问题,MySQL 的问题 也是非常多,最近我也经常面试,也希望问一些数据库一些偏理论和底层的东西,来考察同学对技术的理解程度, 之后 我会更新这个系列的 面试。

主要更新的内容主要是: 我经常面试 一些面试者 喜欢问的一些问题,这是 第一篇 就更新 数据库相关的吧

BTree 基本概念

B树。B树被称为自平衡树,因为它的节点是按顺序遍历排序的。在B树中,一个节点可以有两个以上的孩子。而且高度在每次更新时都会自动调整。在B树中,数据是按照特定的顺序排序的,最低值在左边,最高值在右边。在B树中插入数据或键,比二叉树更复杂。

Btree 的特点:

  • 节点排序,每个节点 可以存放多个元素,多个元素也是排序的
  • 每个节点 key 和数据在一起
  • B树的所有叶子节点必须在同一级别
  • 在B树的叶子节点上面,不应该有空的子树
  • 在关键字全集内做一次查找,性能逼近 二分查找的算法
  • 任何关键字出现且只出现在一个节点中
  • 搜索有可能在非叶子节点结束,因为数据和索引在一起存储的

来一个 max Degree =3 的一个图

在线生成BTree 的图形

在这里插入图片描述

B+Tree 的特点

B+tree 多路平衡查找树:

  • B+Tree 拥有BTree 的所有的结构特点
  • B+Tree 的非叶子节点不存储数据,只存储关键字,叶子节点才存储了所有的数据,并且是排好序的
  • B+Tree 叶子节点是通过指针连接在一起的(双向连接), 这样在范围查询中发挥作用
  • 相对于 Btree , B+tree 层级更低

B+Trees 特点如下:

图形生成地址

在这里插入图片描述

查找过程的区别

两种索引 查找过程的区别:

B+tree 需要找到叶子节点 才能找到数据, 而Btree 可能不需要找到叶子节点 就可以找到数据

B+Tree索引 如何提高索引的查询性能 ?

  • 找得快, 叶子节点双向指针
  • 一次IO 操作,找更多的数据,减少IO 操作,节点不存数据,只存关键字,这样可以存储更多索引的信息,B+tree 层级会降低

为啥 B+Tree 会比 BTree 高度要低呢?

页(Page)是Mysql中磁盘和内存交换的基本单位, 也是Mysql管理存储空间的基本单位。

Page 是InnoDB存储引擎磁盘管理的最小单位,每个页默认16KB,innodb_page_size 可以通过这个参数进行修改

B+Tree 中的非叶子节点 不存储数据, 只存关键字,所以一个Page 中可以容纳更多的索引项, 一是可以降低树的高度,二是 在一个内部节点中可以定位更多的叶子节点。

到此这篇关于Mysql 索引 BTree 与 B+Tree 的区别(面试)的文章就介绍到这了,更多相关Mysql BTree与B+Tre内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SQL中的联合索引和普通索引问题

    SQL中的联合索引和普通索引问题

    这篇文章主要介绍了SQL中的联合索引和普通索引问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • 探讨Mysql中OPTIMIZE TABLE的作用详解

    探讨Mysql中OPTIMIZE TABLE的作用详解

    本篇文章是对Mysql中OPTIMIZE TABLE的作用进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • mysql中字段类型转义方式

    mysql中字段类型转义方式

    这篇文章主要介绍了mysql中字段类型转义方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • MySQL安装出现The configuration for MySQL Server 8.0.28 has failed. You can...错误的解决办法

    MySQL安装出现The configuration for MySQL Server 8.0.28 has

    这篇文章主要给大家介绍了MySQL安装出现The configuration for MySQL Server 8.0.28 has failed. You can...错误的解决办法,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-09-09
  • window环境下使用VScode连接虚拟机MySQL方法

    window环境下使用VScode连接虚拟机MySQL方法

    这篇文章主要介绍了window环境下使用VScode连接虚拟机MySQL方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • MySql约束超详细介绍

    MySql约束超详细介绍

    MySQL唯一约束(Unique Key)是指所有记录中字段的值不能重复出现。例如,为 id 字段加上唯一性约束后,每条记录的 id 值都是唯一的,不能出现重复的情况
    2022-09-09
  • Mysql大小写敏感的问题

    Mysql大小写敏感的问题

    这篇文章主要介绍了Mysql大小写敏感的问题的相关资料,需要的朋友可以参考下
    2015-03-03
  • Linux下如何通过MySQL二进制包安装MySQL5.7

    Linux下如何通过MySQL二进制包安装MySQL5.7

    这篇文章主要介绍了Linux下如何通过MySQL二进制包安装MySQL5.7,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • 浅谈mysql 树形结构表设计与优化

    浅谈mysql 树形结构表设计与优化

    在诸多的管理类,办公类等系统中,树形结构展示随处可见,本文主要介绍了mysql 树形结构表设计与优化,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • MySQL v5.7.18 解压版本安装详细教程

    MySQL v5.7.18 解压版本安装详细教程

    这篇文章主要介绍了MySQL v5.7.18 解压版本安装详细教程,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-04-04

最新评论