当前位置: 首页 > news >正文

Mysql--基础知识点--112--聚簇索引和非聚簇索引

你问的应该是B 树B+ 树的区别(“B数”是笔误)。这两种都是平衡多路搜索树,广泛用于数据库和文件系统,但结构上有几个关键不同。

核心区别一览

特性B 树B+ 树
数据存储位置所有节点(内部节点 + 叶子节点)都存储数据只有叶子节点存储数据,内部节点只存键(及指针)
叶子节点结构独立,无相互链接所有叶子节点通过双向链表串联
查询稳定性不同数据查询的 I/O 次数可能不同(数据可能在根节点)每次查询都必须走到叶子节点,I/O 次数稳定(等于树高)
范围查询效率较低,需要反复回溯父节点效率极高,从叶子链表直接遍历
空间利用率每个节点都存数据,节点容纳的键数量少内部节点不存数据,可容纳更多键 → 树更矮 → I/O 更少

详细解释

1. 数据分布不同

  • B 树:每个节点既存放索引键,也存放对应的数据行地址(或完整数据)。查找时,如果命中某个内部节点,直接返回数据,不一定到叶子层。
  • B+ 树:内部节点只存放键和指向子节点的指针,数据全在叶子节点。所以查找任何数据都必须走到叶子节点。

2. 叶子节点链表

  • B 树:叶子节点之间没有指针连接。
  • B+ 树:所有叶子节点按键大小顺序,用双向链表相连。这使得范围查询(如WHERE id BETWEEN 10 AND 100)极其高效:找到起始叶子后,沿着链表向后扫描即可,无需反复回溯树结构。

3. 查询性能特征

  • B 树:最好情况(命中根节点)只需 1 次 I/O,最坏情况需要树高次 I/O。因此查询时间不稳定
  • B+ 树:任何查询都需要树高次 I/O(比如 3 次),时间稳定。对于数据库而言,稳定意味着可预测性高,对事务处理更友好。

4. 节点存储能力

  • 假设磁盘页大小为 16KB,键占 8 字节,指针占 6 字节,数据行占 200 字节。
  • B 树:每个节点因为存数据,能放的键数量少 → 树更高 → 查找 I/O 次数多。
  • B+ 树:内部节点只存键和指针,可放几千个键 → 树通常只有 2-4 层 → I/O 次数少且稳定。

为什么 MySQL InnoDB 使用 B+ 树?

  • 更适合范围查询:叶子链表支持高效区间扫描和分页。
  • 更高的扇出(fanout):内部节点不存数据,可大幅降低树高,减少磁盘 I/O。
  • 缓存友好:内部节点可以全部缓存在内存中,查询只需要很少的磁盘读取。
  • 查询性能稳定:避免“好运气”和“坏运气”的巨大差异。

一个直观的例子

假设有一棵高度为 3 的树:

  • B 树:可能根节点就存了数据,查它只要 1 次读盘;但也可能数据在叶子,需要 3 次。
  • B+ 树:任何数据都在第 3 层,永远需要 3 次读盘(根节点常驻内存的话实际 2 次)。虽然看起来“最坏”和 B 树一样,但没有波动,并且范围扫描时 B+ 树完胜。

总结:B+ 树 = B 树 + 叶子链表 + 内部节点不存数据。数据库索引几乎都选 B+ 树,正是因为它对磁盘 I/O 和范围查询做了极致优化。

http://www.gsyq.cn/news/1399902.html

相关文章:

  • 【干细胞突破性进展】中国科学家发现“全能开关”基因,改写再生医学未来!2026最新研究深度解读
  • AWS自动化实战:25个事件驱动与无服务器工作流模式解析
  • 具有当地特色的日照海鲜餐厅推荐
  • 智慧农业监控系统核心文件解析
  • 薄膜铌酸锂光波导 vs 传统铌酸锂波导:基于台阶仪的波导刻蚀深度与损耗差异分析
  • 【应用程序】基于 Spring Boot + Spring AI的虚拟宠物Web 应用(二)
  • Terraform自动化部署Vertex AI模型:基础设施即代码实践指南
  • 【深度实战复盘】校园管理中的“纪律高危型”学生考勤画像可视化全流程分析报告
  • CASCADE架构:AI加速器的矩阵乘法革命
  • Windows系统hidserv.dll文件丢失找不到问题解决
  • 保姆级教程:用CUDA 12.x的异步流和事件,手把手优化你的PyTorch数据预处理流水线
  • 智能体评估误区:为何Token消耗不是衡量AI工作价值的关键指标
  • 从74LS283到Verilog:手把手教你用硬件描述语言‘复刻’经典BCD加法器(附完整代码与Testbench)
  • springboot - jar包启动指定具体的jdk执行
  • AI代理循环成本优化:Lumin本地代理层实现请求瘦身与缓存压缩
  • CTV广告变现中10个致命的VAST错误与优化实战
  • DeepSeek V4 Pro降价后开发者该怎么用?附API接入与成本优化指南
  • Figma 设计图上传到蓝湖
  • Unity PC端内嵌网页开发避坑指南:从Embedded Browser 3.1.0插件安装到与Vue页面交互
  • Android内存泄漏检测利器:LeakCanary深度解析与实践指南
  • HSM - 分层状态机
  • 活久见的突发:AI比人贵了?微软禁自家工程师用AI
  • 2026年恒温恒湿试验箱厂家筛选与老化试验箱厂家推荐 从研发产能到定制服务全方位解析选型要点 - 栗子测评
  • 淘来的二手Mellanox CX4 25G网卡,用lspci命令怎么快速验货和看关键信息?
  • Django 从 0 到 1 打造完整电商平台:商品缓存优化(Redis)
  • Lovable平台与SCADA系统集成失败率高达41%?——揭秘OPC UA协议握手阶段被忽略的2个时序陷阱
  • SQL核心技能全景图:DDL数据定义、DML安全操作、DQL高级查询、多表JOIN与窗口函数实战
  • 前门准则扩展:图模型视角下因果效应识别条件的放宽与验证
  • 【Lindy翻译工作流自动化实战指南】:20年本地化专家亲授5大不可跳过的自动化陷阱与避坑清单
  • Anthropic的“部署即收购”:企业AI如何通过私募股权网络实现指数级增长