什么是回表查询

"回表查询"是 数据库索引使用中的一个概念 ,尤其常见于 MySQL InnoDB 存储引擎


1️⃣ 回表查询的定义

回表查询(Index Lookup + Table Access / Bookmark Lookup)

指查询时使用了 非覆盖索引(non-covering index),索引本身没有包含查询需要的全部列,需要通过索引找到主键或行指针,然后再回到聚簇索引(或者数据表)去读取完整行数据的过程。

简单来说:

  1. 先在索引中找到匹配的键值和对应的行指针(主键)。
  2. 再根据主键去 表(叶子节点) 找完整的行数据。

2️⃣ 举例说明

假设有一张表 user

sql 复制代码
CREATE TABLE user (
    id INT PRIMARY KEY,
    name VARCHAR(20),
    age INT,
    INDEX idx_name(name)
);
  • idx_name 索引只包含 nameid(因为是二级索引,InnoDB 二级索引里存的是索引列 + 主键)。
  • 查询:
sql 复制代码
SELECT age FROM user WHERE name = 'Alice';
  • 索引 idx_name 里有 name='Alice' 对应的 id=101

  • 但是我们要查询的列是 age,索引里没有。

  • 回表步骤

    1. idx_name 索引中找到 name='Alice'id=101
    2. 再用 id=101 去聚簇索引(表)中找到 age 列的值。
  • 这个额外的访问表的过程,就是 回表查询


3️⃣ 回表查询的特点

  • 触发条件:非覆盖索引、查询列不在索引中。

  • 开销:会多一次访问表(磁盘 I/O 或 Buffer Pool)。

  • 优化方式

    1. 覆盖索引:在索引里包含查询的所有列。

      sql 复制代码
      CREATE INDEX idx_name_age ON user(name, age);

      这样查询 SELECT age FROM user WHERE name='Alice'; 就不需要回表。

    2. 尽量使用主键查询,避免二级索引回表。

    3. 查询时只选索引列,减少回表。


💡 总结一句话:

回表查询就是:先用二级索引找到主键,再用主键去表里获取完整行数据的过程。


相关推荐
摇滚侠19 小时前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
ApacheSeaTunnel21 小时前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
DARLING Zero two♡1 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
活宝小娜1 天前
mysql详细安装教程
数据库·mysql·adb
Database_Cool_1 天前
什么是数据仓库物化视图?AnalyticDB MySQL 实时物化视图能力解析
人工智能·mysql·阿里云
Database_Cool_1 天前
即席查询(Ad-Hoc)数据库选型:AnalyticDB MySQL 秒级 Ad-Hoc 分析方案
数据库·mysql
一杯奶茶¥1 天前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
用户800391387831 天前
使用 Gemini 解决 MySQL 常见问题
mysql
Database_Cool_1 天前
什么是湖仓一体?和数据仓库的本质区别(附 AnalyticDB MySQL 湖仓一体方案)
数据库·数据仓库·mysql
XZ-0700011 天前
MySQL事务
数据库·mysql·oracle