网站首页 > 技术文章 正文
回表与覆盖索引对比
概念定义
回表查询
当使用非聚簇索引(二级索引)查询时,若所需字段未完全包含在索引中,需根据索引记录的主键值回到聚簇索引(主键索引)中查询完整数据行,此过程称为回表。例如:通过 username 索引找到主键 id 后,还需回主键索引获取 email 和 age 字段。
覆盖索引
索引包含查询所需的所有字段(SELECT 字段 + WHERE 条件),可直接从索引树获取结果,无需回表操作。例如:联合索引 (username, age) 覆盖查询 SELECT username, age FROM users,直接返回索引数据。
执行过程对比
场景 | 回表查询 | 覆盖索引 |
查询示例 | SELECT email FROM users WHERE username='A' | SELECT username FROM users WHERE username='A' |
索引结构 | username索引仅存 username和 id | (username, email)索引包含全部查询字段 |
执行步骤 | 1. 查询 username索引获取 id | 直接通过联合索引返回 username和 email |
磁盘 I/O | 两次(索引树 + 聚簇索引) | 一次(仅索引树) |
示例说明
回表示例
-- 表结构:id(主键), username(索引), email
SELECT email FROM users WHERE username = 'John';- 执行过程:通过 username 索引找到 id → 回表查询主键索引获取 email。
覆盖索引示例
-- 创建覆盖索引:ALTER TABLE users ADD INDEX idx_username_email(username, email);
SELECT username, email FROM users WHERE username = 'John';- 优势:索引 idx_username_email 直接包含查询字段,无需回表。
优化建议
优先设计覆盖索引
- 将高频查询的字段合并为联合索引,如 (a, b, c) 覆盖 SELECT a, b, c。避免 SELECT *,减少索引外的字段查询。
权衡索引开销
- 覆盖索引可能增加索引体积,影响写入性能,需平衡查询效率与存储成本。
利用最左匹配原则
- 联合索引 (a, b) 可覆盖查询 WHERE a=1 AND b=2,但无法覆盖 WHERE b=2。
性能影响对比
指标 | 回表查询 | 覆盖索引 |
磁盘 I/O | 高(两次访问) | 低(一次访问) |
查询延迟 | 较高 | 较低 |
适用场景 | 查询非索引字段 | 查询仅含索引字段 |
通过合理设计索引,覆盖索引可减少 50% 以上的 I/O 开销。
猜你喜欢
- 2025-09-03 InnoDB 聚集索引和非聚集索引、覆盖索引、回表、索引下推简述
- 2025-06-10 如何理解Mysql的索引及他们的原理?
- 2025-06-10 性能测试——测试常见的指标(测试性能指标有哪些)
- 2025-06-10 mysql中的分区表和合并表详解(一个常见知识点)
- 2025-06-10 Oracle优化-建立索引(三)(oracle 索引优化)
- 2025-06-10 MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
- 2025-06-10 你写的 SQL 查询为什么总是慢?揭秘 MySQL 索引机制与联合索引
- 2025-06-10 数据库主从复制,读写分离,分库分表,分区详解
- 2025-06-10 如何在在量化交易程序中高效使用sqlite
- 2025-06-10 「Python数据分析」Pandas进阶,使用merge()函数合并数据
- 12-19电脑不显示我的电脑(电脑开机后进不了桌面)
- 12-19如何清理c盘没用的垃圾(如何清理c盘没用的垃圾文件)
- 12-19域名服务器查询(域名服务器查询方式)
- 12-19163邮箱手机版登录页面(163邮箱手机版登录页面在哪)
- 12-19仙剑奇侠传四手机版单机(单机版仙剑4能在手机玩吗)
- 12-19电脑上截图的快捷键怎么操作
- 12-19电子邮箱注册163(电子邮箱注册入口官网)
- 12-19win10电脑c盘怎么扩大(window10电脑c盘怎么扩大)
- 最近发表
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (77)
- vector线程安全吗 (73)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)
