MySQL中B+树索引的深度剖析

MySQL中B+树索引的深入解析

一、索引的减少I/O设计

1. 读取量相关

当从硬盘中搜索并读取查询记录时,由于硬盘单次读取数据到内存的时间远高于内存内操作数据的时间,MySQL通过对索引数据结构的设计来减少查询记录时的硬盘I/O次数。每个B+搜索树节点的存储空间对应硬盘的一个页,这样能最大程度利用硬盘单次读取的页容量,减少读取次数。

2. 搜索树特性

2.1 搜索方向

在搜索树中进行查询时,会朝着正确范围且符合正向增长概率的方向进行搜索,避免无效遍历,最终能精确匹配目标记录。

2.2 有序性

搜索树结构保证了记录值依据字段键的有序排列,这使得能够通过字段进行范围查询以及排序操作。与哈希表对比,哈希表虽能实现O(1)的精确查询,但内部是无序数组,无法进行范围查询和排序。

3. 多叉结构分析

3.1 B树的局限

B树以键值对为单位存储,然而在数据库场景下,值记录空间较大而键字段空间较小,导致单个节点能存储的键值对有限,向下分支少,树高较高,使得硬盘I/O次数增多,且查询时间开销不稳定,因为值记录可能分布在非叶子和叶子节点,读取效率不一致。

3.2 B+树的优势

B+树将键与值分开存储,非叶子节点仅存储搜索字段,能大量排布键字段,实现高效的分叉搜索。非叶子节点的字段总量较小可缓存到内存,首次查询时通过B+树高度次硬盘读取加载非叶子节点到缓存,后续查询可在缓存中快速搜索,时间复杂度低。非叶子节点在区间搜索时会向下保留区间键,叶子节点存储全集键值对且通过链表物理连续连接,保证了范围查询的高效性,且查询固定在叶子节点进行,时间开销稳定。

二、索引的操作

1. 查看

可通过以下语句查看表的索引:

show index from tb_name;
show create table tb_name;

用于查看表中所有的索引信息。

2. 创建索引

2.1 创建时机

建议在表数据为空或数据量较小时创建索引,此时创建索引对性能影响较小。

2.2 大表索引创建
2.2.1 直接创建过程

为记录量大的表创建索引时,B+树按1000次方的节点数量向下构建。从顶层根节点开始,每层节点按1000个键字段分叉,逐步构建直到叶子节点覆盖所有字段全集。

2.2.2 危险性

直接为海量数据的表创建索引会导致服务器短时间大量资源用于构建索引,可能出现挂机状态。

2.2.3 正确创建做法

若需为海量数据的表创建索引,可在另一台MySQL服务器创建相同结构空表并创建索引,控制数据量导入建树,完成后切换服务器使用。

3. 删除索引

通过以下语句删除表中的指定索引:

drop index idx_name on tb_name;

用于删除表中的指定索引

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12959.html

(0)
LomuLomu
上一篇 2025 年 7 月 23 日
下一篇 2025 年 7 月 23 日

相关推荐

  • 华为OD机试E卷 –流浪地球–24年OD统一考试(Java & JS & Python & C & C++)

    文章目录 题目描述 输入描述 输出描述 用例 题目解析 JS算法源码 Java算法源码 python算法源码 c算法源码 c++算法源码 题目描述 流浪地球计划在赤道上均匀部署了N个转向发动机,按位置顺序编号为O~N-1。1)初始状态下所有的发动机都是未启动状态;2)发动机起动的方式分为“手动启动”和“关联启动”两种方式;3)如果在时刻1一个发动机被启动,下…

    未分类 2025 年 1 月 21 日
    87900
  • 使用java -jar命令运行jar包提示“错误:找不到或无法加载主类“的问题分析

    用maven把普通java项目打包成可运行的jar后,打开cmd用java -jar运行此jar包时报错: 用idea运行该项目则没有问题 。 其实原因很简单,我们忽略了2个细节。 java指令默认在寻找class文件的地址是通过CLASSPATH环境变量中指定的目录中寻找的。 我们忽略了package的影响。 第一个问题好解决: 我们直接在CLASSPAT…

    2025 年 1 月 10 日
    99500
  • 一键拥有最新idea激活码+最新破解教程合集

    免责声明:下文所涉 IDEA 2025.2.1 破解补丁及激活码均源自互联网公开资源,仅供个人学习研究,禁止商业用途。若条件允许,请支持正版!如有侵权,请联系作者删除。 先放一张“战果”——IDEA 已顺利激活至 2099 年,爽歪歪! 下面用图文方式,手把手带你完成最新版 IntelliJ IDEA 的破解流程。 嫌折腾?官方正版全家桶账号 32 元/年,…

    IDEA破解教程 2025 年 10 月 16 日
    20700
  • 一文汇总webstorm激活码所有获取方式与实用破解教程

    声明:以下破解补丁与激活码均来自互联网,仅供个人学习交流,禁止商业用途。如条件允许,请支持正版! WebStorm 是 JetBrains 出品的跨平台前端 IDE,Windows、macOS、Linux 均可使用。下面手把手教你用破解补丁一键永久激活,解锁全部高级功能。无论哪个版本、哪种系统,步骤都已为你梳理完毕。 激活成功效果预览 激活后,授权界面会显示…

    2025 年 11 月 8 日
    20300
  • DataGrip激活方式推荐|新手也能一步到位!

    本方案适用于 IntelliJ IDEA、PyCharm、DataGrip、GoLand 等 JetBrains 全系产品,无需区分版本号,新旧通杀! 先放一张成功截图镇楼:已经顺利把 DataGrip 激活到 2099 年,稳! 下面用图文方式手把手演示 DataGrip 的 2099 年激活流程,Win / macOS / Linux 全平台通用,旧版本…

    DataGrip激活码 2025 年 9 月 16 日
    23700

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信