MySQL-聚簇索引

聚簇索引是什么,如何构建的,如何回表

聚簇索引(InnoDB)完整讲解:概念、构建、回表(结合前面案例)

一、聚簇索引 基本概念

1. 定义

聚簇索引(聚集索引) InnoDB 引擎特有,主键就是聚簇索引表的数据行本身就存在聚簇索引的叶子节点中

  • 一张 InnoDB 表有且仅有一个聚簇索引
  • 数据和索引物理存放在一起,叶子节点 = 整行数据
  • 无主键时,InnoDB 会自动选唯一非空列 / 隐藏列充当聚簇索引

2. 和普通二级索引核心区别

  • 聚簇索引叶子:整行所有字段数据
  • 二级索引(普通 / 唯一 / 前缀索引)叶子:索引字段值 + 主键值

二、聚簇索引如何构建(结合示例表)

沿用表 student,主键 sid,数据如下:

表格

sid (主键) sname
1 张三
2 张三丰
3 张小花
4 李四
5 李磊
6 王五

1. 构建规则

  1. 主键 sid 作为排序依据,按主键值升序 组织成 B + 树
  2. 非叶子节点:只存主键分界值,用于检索引路;
  3. 叶子节点按主键有序存放完整的一行数据(主键 + 姓名 + 所有字段);
  4. 叶子节点之间用双向链表串联。

2. 聚簇索引 B + 树 结构(可视化)

plaintext

复制代码
            根节点(非叶子,存主键分界值:3)
                  ↓
    左分支(≤3)        右分支(>3)
┌──────────────┐  ┌──────────────┐
│叶子节点组1    │  │叶子节点组2    │
│(1,张三)      │  │(4,李四)      │
│(2,张三丰)    │  │(5,李磊)      │
│(3,张小花)    │  │(6,王五)      │
└──────────────┘  └──────────────┘
  • 每一条叶子数据 = 主键 + 整行数据
  • 整张表的数据,全部集中在聚簇索引的叶子节点里

3. 构建过程简述

  1. 建表指定 PRIMARY KEY(sid),系统自动创建聚簇索引;
  2. 插入数据时,按主键 sid 大小排序,依次写入 B + 树 叶子节点;
  3. 数据增多、节点分裂时,自动向上更新非叶子分界节点;
  4. 最终形成一棵以主键排序、数据与索引合一的 B + 树。

三、什么是回表?为什么要回表?

1. 回表定义

通过二级索引 查到主键值 后,再拿着这个主键去聚簇索引 中查询完整行数据,这个过程就叫 回表

2. 产生原因

二级索引(前缀索引 / 普通索引)叶子只存:索引字段 + 主键没有完整数据,必须借助主键去聚簇索引拿全数据。


四、结合「查找张三丰」完整演示:二级索引 → 回表 → 聚簇索引

场景回顾

查询语句:

sql

复制代码
SELECT * FROM student WHERE sname = '张三丰';

索引:sname(2) 前缀索引(二级索引)

完整流程(分两大阶段)

阶段 1:走【前缀二级索引 B + 树】拿到主键

  1. 截取查询值 张三丰 前 2 位:张三
  2. 进入前缀索引 B + 树,二分查找定位叶子节点;
  3. 匹配到两条前缀为张三的索引项:
    • (张三, sid=1)
    • (张三, sid=2)
  4. 得到候选主键:12

阶段 2:【回表】------ 用主键查询【聚簇索引 B + 树】

  1. 拿着主键 sid=1 进入聚簇索引:

    • 从根节点按主键二分查找,定位叶子节点;
    • 取出整行数据:sid=1,sname=张三
    • 对比完整姓名,不匹配,丢弃。
  2. 拿着主键 sid=2 进入聚簇索引:

    • 按主键找到对应叶子节点;
    • 取出整行数据:sid=2,sname=张三丰
    • 完全匹配,保留结果。
  3. 最终返回该行数据,回表过程结束


五、关键考点总结(背诵版)

  1. 聚簇索引InnoDB 主键即聚簇索引,数据行直接存于 B + 树 叶子节点,一张表仅有一个。构建时按主键值升序组织 B + 树,非叶子节点存主键分界值用于查找。

  2. 回表二级索引仅保存索引字段 + 主键,无法获取完整数据;利用二级索引查到主键后,再通过主键访问聚簇索引读取整行数据,该过程称为回表。

  3. 补充考点

  • 覆盖索引:查询字段全部在二级索引中,无需回表
  • 前缀索引:一定产生回表(只存部分字符);
  • 主键查询:直接走聚簇索引,无回表
相关推荐
qq_185198691 小时前
ruoyi框架中配置minio
数据库
Access开发易登软件1 小时前
Access 用 VBA 操作 SQLite,不用装任何驱动
jvm·数据库·sqlite·vba·access·access开发
字节跳动数据库1 小时前
火山引擎 Milvus 发布官方 CLI + Skill ,终端与对话双通道掌控向量数据库
数据库·人工智能
夜白宋1 小时前
【Redis深入】一、快的原因
数据库·redis·缓存
念越1 小时前
【数据库系统概论期末复习】 绪论重点与常考题重点与常考题整理第一章
数据库·数据库系统概论
SXJR1 小时前
langchain4j是如何保证tools或者funcation call不出错的
java·网络·数据库·ai·语言模型
AIMath~2 小时前
兼容pymongo=4.16版本如何安装mongodb
数据库·mongodb
念恒123062 小时前
MySQL连接池原理与简易网站数据流动是如何进行的
数据库·mysql
宇砾2 小时前
浅谈Redis(2)
数据库·redis·缓存