【MySQL-索引调优】04:回表相关概念

PS:现在orders表中存在idx_user_id(user_id),以及idx_user_status(user_id, status)两个索引

1-例子

假设orders表内部有10w条数据,满足user_id = 1 AND status = 1的有5w条,运行:

mysql 复制代码
SELECT user_id, status, amount FROM orders  WHERE user_id = 1 AND status = 1;

此时会用到联合索引idx_user_status(user_id, status),但是我们还查询了一个字段amount,此时,就要去回表了,就是用现在的结果,再通过id去拿amount,流程如下:

bash 复制代码
步骤1: 在二级索引 idx_user_status 中找到 50,000 个匹配项
        ↓
步骤2: 对每一条记录,拿着主键 id 去回表查 amount
        ↓
        ├─> 回表 1 次:根据 id=101 去聚簇索引查 amount
        ├─> 回表 2 次:根据 id=205 去聚簇索引查 amount
        ├─> ... 重复 50,000 次 ...
        └─> 回表 50,000 次:根据 id=xxxxx 查 amount
        
        ↓
步骤3: 返回结果

PS:针对高频查询,尽量让 WHERE 条件 + SELECT 字段 都被同一个索引覆盖,彻底消灭回表

2-回表

用现在的结果,再通过id去拿其他信息

3-回表的方式

  • MySQL的InnoDB存储引擎里,二级索引(比如你建的联合索引)存储的是索引字段 + 主键值
  • 当你需要额外字段(如amount),数据库会用索引定位到主键,然后再通过主键去表里查对应的行
  • 所以确实是每一条匹配的记录都要回表一次,在上方的例子里就是5万次回表
相关推荐
睡不醒男孩03082310 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐12 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪12 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通13 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..13 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_291414 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜14 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊15 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅15 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 202316 小时前
Vue复习
linux·服务器·数据库