当前位置: 首页 > news >正文

网站建设国内外研究现状推广普通话手抄报内容怎么写

网站建设国内外研究现状,推广普通话手抄报内容怎么写,宠物店网站建设计划书,西安免费企业网站模板图片1. 什么是回表? 回表(Back to Table) 指的是 在使用非聚簇索引(辅助索引)查询时,MySQL 需要 先通过索引找到主键 ID,然后再回到主键索引(聚簇索引)查询完整数据&#xf…

1. 什么是回表?

回表(Back to Table) 指的是 在使用非聚簇索引(辅助索引)查询时,MySQL 需要 先通过索引找到主键 ID,然后再回到主键索引(聚簇索引)查询完整数据,这一过程称为回表。


2. 回表的示例

假设有一张 users 表:

CREATE TABLE users (id INT PRIMARY KEY,       -- 主键name VARCHAR(50),         -- 用户名age INT,                  -- 年龄address VARCHAR(255),      -- 地址INDEX idx_name (name)      -- 创建 name 的辅助索引
) ENGINE=InnoDB;

如果执行以下查询:

SELECT address FROM users WHERE name = 'Alice';

查询执行过程:

  1. 先查 idx_name 索引,找到 name='Alice' 对应的 id(假设 id = 3)。
  2. 再回表查询,根据 id=3 在聚簇索引(主键索引)中找到 address 字段。

为什么要回表? 因为 idx_name 只存了 nameid,但 address 不在索引中,必须再回到主键索引查找完整数据。


3. 什么情况下会发生回表?

  • 查询的字段不在索引覆盖范围内(即非覆盖索引查询)。
  • 使用二级索引(非主键索引)查询,而查询的字段不在索引列中。

4. 如何避免回表?

(1)使用覆盖索引

如果查询的字段已经包含在索引中,就可以避免回表

CREATE INDEX idx_name_age ON users(name, address);

然后执行:

SELECT address FROM users WHERE name = 'Alice';

此时,idx_name_age 索引已经包含 nameaddress,所以可以直接在索引中获取数据,不需要回表

(2)使用主键查询

如果使用 id(主键)查询,就不需要回表:

SELECT address FROM users WHERE id = 3;

因为 InnoDB 的主键索引(聚簇索引)本身就存储了完整数据,所以查询 id 不会回表。


5. 总结

查询方式是否回表原因
主键查询 (SELECT * FROM users WHERE id = 3)不会因为主键索引(聚簇索引)包含完整数据
非主键索引查询 (SELECT address FROM users WHERE name = ‘Alice’)会回表先查 name 索引,再回表查 address
覆盖索引查询 (SELECT name FROM users WHERE name = ‘Alice’)不会name 索引已经包含查询字段

🚀 结论: MySQL InnoDB 避免回表的方法

  1. 尽量使用覆盖索引(让查询的所有字段都包含在索引中)。
  2. 使用主键查询,避免使用非主键索引查询非索引字段。
  3. 分析 EXPLAIN 结果,关注 Extra 字段是否包含 "Using index"(表示使用了覆盖索引)。

这样可以减少回表,提高查询性能!🚀

6. 拓展:二级索引的叶子节点和非叶子节点存储内容**

6.1 二级索引 B+ 树结构示意

假设有如下 users 表:

CREATE TABLE users (id INT PRIMARY KEY,  -- 聚簇索引name VARCHAR(50),age INT,INDEX idx_age (age)   -- 二级索引
);

其中,表中的数据如下:

idnameage
1Alice25
2Bob30
3Charlie35

6.2 完整的二级索引 B+ 树结构
                (30)/    \(25)      (35)/      \     /    \(age=25,id=1) (age=30,id=2) (age=35,id=3)
6.3 📌 结构解析
  • 非叶子节点(索引键)
    • 只存储 索引列 age,用于 快速查找数据所在的叶子节点
    • 例如,30 代表左侧存 <30 的数据,右侧存 >=30 的数据。
  • 叶子节点(存储实际索引数据)
    • 存储 索引列 age主键 id,但 不存储完整数据
    • 例如,叶子节点 (age=30, id=2) 说明 age=30 的数据,主键 id=2
    • 叶子节点 通过主键 id 回表查询完整数据

6.4 二级索引查询流程

查询 SELECT * FROM users WHERE age = 30;

  1. 从非叶子节点找到 30 对应的叶子节点。
  2. 叶子节点存储 (age=30, id=2),返回 id=2。
  3. 回表:用 id=2 查询 users 表的主键索引,获取完整数据。

6.5 🔥 关键点总结
  1. 非叶子节点 只存索引 key(age),不存储数据
  2. 叶子节点age主键 ID,用于返回 ID 进行回表查询。
  3. 回表查询 是因为 二级索引不存完整数据,需要用主键 ID 进一步查询。
  4. 优化方式:
    • 覆盖索引(例如 INDEX idx_age_name (age, name)),让查询字段直接存入索引,避免回表。
    • 合理设计主键,避免主键过大影响二级索引的存储效率。

这样,你对二级索引的 存储结构和查询流程 是否更加清晰了呢? 😊🚀

http://www.cadmedia.cn/news/6120.html

相关文章:

  • 郑州市网站空间服务公司如何做网站推广及优化
  • 山东省建设厅网站空间刷赞网站推广
  • 图书馆网站建设情况总结网络推广法
  • 东莞网站建设求职百度客服人工服务电话
  • 东莞互联网营销网站建设国际新闻 军事
  • 做个公司网站需要什么钱google 优化推广
  • 好的门户网站怎样推广一个产品
  • 好看的网站建设公司优化方案官网电子版
  • 信阳网站seo千牛怎么做免费推广引流
  • 做网站老板嫌弃太丑谁的锅百度推荐现在为什么不能用了
  • 网站建设的基本概念常见的搜索引擎有哪些?
  • 做网站展示软件seo搜索优化公司排名
  • 衡阳做淘宝网站建设百度广告代理公司
  • 购买域名网站莆田网站建设优化
  • 云南昆明网站建设公司培训网站推广
  • 哪些网站可以做画赚钱网站建设服务商
  • 成都科技网站建设热竞价推广开户多少钱
  • 什么软件可以做网站优化大师电脑版官网
  • 无货源电商一件代发怎么做seo关键词排名优化怎样收费
  • 在线室内设计工具杭州关键词优化平台
  • 江西核工业建设有限公司网站铁力seo
  • 无证做音频网站违法吗seo网站整站优化
  • 建设部执业考试网站市场营销计划方案
  • 广告策划方案西安seo关键词推广
  • 入口网站推广最新的疫情信息
  • 嘉兴市建设局网站网络推广有几种方法
  • 长春网站建设专业公司最大的推广平台
  • 莱芜共青团网站app开发工具哪个好
  • 黑马程序员官方网站百度广告推广怎么做
  • 德育工作网站建设方案郑州网站制作公司哪家好