0

0

Java面试之MySQL聚簇索引与非聚簇索引

幻夢星雲

幻夢星雲

发布时间:2026-01-05 05:15:35

|

156人浏览过

|

来源于php中文网

原创

聚簇索引即数据按主键顺序直接存储在b+树叶子节点中;innodb以primary key为聚簇索引,无主键时选not null unique列或隐式row_id;二级索引叶子存主键值以避免行迁移导致的指针更新。

java面试之mysql聚簇索引与非聚簇索引

聚簇索引的物理存储到底长什么样

聚簇索引不是“加了索引就聚簇”,而是数据行直接按索引键顺序存放在B+树叶子节点里。InnoDB中,PRIMARY KEY自动成为聚簇索引——这意味着整张表的数据文件(.ibd)本身就是一颗B+树,叶子节点存的是完整的行记录。

如果建表时没定义主键,InnoDB会按以下顺序选聚簇索引:先找NOT NULL UNIQUE列;找不到就隐式生成一个6字节row_id列作为聚簇索引。这个row_id不可见、不可查,但会影响插入性能和页分裂行为。

  • 聚簇索引查询主键时是“一次IO”:直接定位到叶子页,拿到完整行
  • 范围扫描(如WHERE id BETWEEN 100 AND 200)天然有序,效率高
  • 更新主键值会导致整行移动(可能跨页),代价远高于更新非主键字段

为什么二级索引叶子节点存的是主键值而不是行指针

InnoDB的二级索引(即非聚簇索引)叶子节点不存磁盘地址或行偏移,而是存对应记录的PRIMARY KEY值。这是为了规避行迁移问题:一旦行物理位置变动(比如页分裂、UPDATE导致行变长),所有二级索引都不需要更新指针——只需用主键值回表查即可。

这也带来一个关键约束:二级索引的WHERE条件若不能覆盖所需字段,就必须回表。例如SELECT name FROM user WHERE email = 'a@b.c',即使email上有索引,只要name不在该索引中,就得拿着查到的主键再去聚簇索引里捞一次。

立即学习Java免费学习笔记(深入)”;

墨刀AIPPT
墨刀AIPPT

排版/配图/美化一键优化,3分钟产出专业级PPT

下载
  • 联合索引(a, b)能覆盖SELECT a, b FROM t WHERE a = ?,无需回表
  • 但如果写成SELECT * FROM t WHERE a = ?,哪怕a是联合索引首列,仍要回表取其他列
  • EXPLAINExtra字段出现Using index condition说明用了ICP(索引下推),但不等于免回表

MyISAM的非聚簇索引和InnoDB有本质区别

MyISAM的索引文件(.MYI)和数据文件(.MYD)完全分离,所有索引(包括主键)都是非聚簇的:索引叶子节点存的是行在.MYD文件中的offset(偏移量)。这意味着:

  • MyISAM没有真正的“聚簇索引”,它的主键索引只是逻辑上唯一+非空,物理上仍是二级索引结构
  • 主键查询需两次IO:先查索引得offset,再按offset读数据文件
  • 没有“回表”概念,但有“二次寻址”;也没有“因主键更新导致行移动”的问题

这也是为什么MyISAM支持INSERT DELAYED、并发插入更简单——它不维护行物理顺序。

面试常问的“主键选UUID还是自增?”背后是聚簇索引特性

UUID做主键,写入时新值随机分布,极易引发页分裂和大量随机IO;而BIGINT AUTO_INCREMENT保证递增写入,基本顺序追加,页利用率高、缓存友好。

但注意:这不是UUID本身的问题,而是它破坏了聚簇索引“有序写入”这一核心优势。如果你强制用UUID,又想缓解影响,可考虑:

  • 使用UUID_TO_BIN(UUID(), 1)将UUID转为二进制并倒序存储(MySQL 8.0+)
  • 业务层生成时间前缀+随机后缀的“有序UUID”,再转为BINARY(16)
  • 接受写入性能损失,但确保innodb_page_size足够大(如16K)、innodb_fill_factor调低(如80)预留页空间
SELECT UUID_TO_BIN('6b14e5a0-9f8c-11ef-9f0a-00155d012345', 1);

真正容易被忽略的是:即使你没显式定义主键,只要表里有NOT NULL UNIQUE列,InnoDB就可能拿它当聚簇索引——而这类列往往不是递增的。上线前务必用SHOW CREATE TABLE确认实际聚簇索引列。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

685

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

493

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

266

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

666

2023.08.14

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 844人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号