news 2026/5/10 9:12:06

MySQL EXPLAIN type 类型性能层级分析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL EXPLAIN type 类型性能层级分析

针对上图阿里Java开发手册中的说明,本文我来详细分析 MySQL EXPLAIN 中的type类型,并按照性能从优到劣排序:

📊MySQL EXPLAIN type 类型性能层级

🏆第1梯队:最优性能

1. system
  • 表中只有一行数据(系统表)
  • 这是最好的情况,但很少见
2. const
  • 通过主键或唯一索引进行等值查询
  • 最多只返回一条记录
  • 示例:WHERE id = 1(id是主键)
  • 优化阶段就能确定结果

🥈第2梯队:优秀性能

3. eq_ref
  • 多表连接时,使用主键或唯一索引进行关联
  • 对于前表的每一行,后表最多匹配一行
  • 常见于INNER JOIN中主键关联
4. ref
  • 使用普通索引进行等值查询
  • 可能返回多条记录
  • 示例:WHERE name = '张三'(name有普通索引)

🥉第3梯队:可接受性能

5. range
  • 对索引进行范围扫描
  • 示例:WHERE id > 100BETWEENIN
  • 比全表扫描好得多

⚠️第4梯队:需要优化

6. index
  • 索引全扫描:扫描整个索引树
  • 虽然比全表扫描快(因为索引通常比表小)
  • 但仍然是线性扫描,性能较差
  • 示例:SELECT id FROM table(id是索引)
7. ALL
  • 全表扫描
  • 性能最差,需要扫描所有数据行
  • 数据量大时非常缓慢

📈性能对比表

级别 | 扫描方式 | 性能 | 说明 -----------|------------------|----------|------------------- system | 系统表 | ★★★★★ | 只有一行 const | 主键/唯一索引等值 | ★★★★☆ | 最多一行 eq_ref | 主键关联 | ★★★★☆ | 连接优化 ref | 普通索引等值 | ★★★☆☆ | 推荐目标 range | 索引范围 | ★★☆☆☆ | 最低要求 index | 索引全扫描 | ★☆☆☆☆ | 需要优化(反例) ALL | 全表扫描 | ☆☆☆☆☆ | 必须优化

🔍如何从 type 判断查询效率

好的情况

  • const/eq_ref:最优,秒级响应
  • ref:良好,毫秒级响应
  • range:可接受,数据量大时可能需要优化

差的情况

  • index:虽然比 ALL 好,但仍是线性扫描
  • ALL:必须优化,否则会随数据量增长而急剧变慢

💡优化建议

1.至少达到 range 级别

-- 优化前:可能 type=ALLSELECT*FROMusersWHEREage>25;-- 优化后:type=range-- 给 age 字段添加索引CREATEINDEXidx_ageONusers(age);

2.争取达到 ref 级别

-- 优化前:type=range(因为用了范围查询)SELECT*FROMordersWHEREuser_idIN(1,2,3);-- 如果业务允许,改为等值查询SELECT*FROMordersWHEREuser_id=1;

3.尽可能达到 const

-- 使用主键或唯一索引SELECT*FROMusersWHEREid=1;SELECT*FROMusersWHEREemail='user@example.com';-- email需是唯一索引

📝实际查询示例分析

-- 假设 users 表有:-- id (主键), name (普通索引), age (无索引), email (唯一索引)EXPLAINSELECT*FROMusersWHEREid=1;-- type: const ✓ (最优)EXPLAINSELECT*FROMusersWHEREemail='test@example.com';-- type: const ✓EXPLAINSELECT*FROMusersWHEREname='张三';-- type: ref ✓ (良好)EXPLAINSELECT*FROMusersWHEREage>25;-- type: ALL ✗ (需要给 age 加索引)EXPLAINSELECTidFROMusers;-- type: index ✗ (虽然只查索引列,但仍是全索引扫描)

🎯总结关键点

  1. const > ref > range > index > ALL(性能递减)
  2. 目标:至少达到range,争取达到ref,最好是const
  3. index 类型并不好:虽然是扫描索引,但仍是线性扫描,特别是大数据表时要避免
  4. 优化手段:添加合适的索引、改写查询条件、避免全表扫描
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 6:56:26

学长亲荐10个AI论文工具,本科生搞定毕业论文不求人!

学长亲荐10个AI论文工具,本科生搞定毕业论文不求人! AI 工具如何让论文写作变得轻松高效? 在当今学术环境中,越来越多的本科生开始借助 AI 工具来辅助论文写作。这些工具不仅能显著降低 AIGC(人工智能生成内容&#xf…

作者头像 李华
网站建设 2026/5/5 17:30:34

【课程设计/毕业设计】基于java教材征订管理系统基于微服务教材征订系统【附源码、数据库、万字文档】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/5/1 7:58:50

2025国内评价高的宠物项圈权威榜单重磅发布

行业痛点分析当前宠物项圈领域面临着诸多技术挑战。一方面,定位精度不足是一大难题。在复杂城市环境中,宠物活动范围广,传统项圈的定位误差较大,难以准确追踪宠物位置。测试显示,部分项圈在高楼林立区域的定位误差可达…

作者头像 李华
网站建设 2026/5/8 15:33:04

为了过知网检测,我自费测了十大降AI平台,最好用的都在这了

家人们,现在学校查得是真严,不仅重复率,还得降ai率,学校规定必须得20%以下... 折腾了半个月,终于把市面上各类方法试了个遍,坑踩了不少,智商税也交了。今天这就把这份十大降AI工具合集掏心窝子…

作者头像 李华
网站建设 2026/5/2 20:07:28

【在Ubuntu22.04下,微星z790主板装机后无wifi模块】

在Ubuntu22.04下,微星z790主板装机后无wifi模块因为微星最新一批的支持wifi7的主板全都是高通的wifi模块,所以装机后没有网卡驱动,不显示wifi,解决方法为找一跟数据线把手机连接到电脑主机上,开启usb网络共享&#xff…

作者头像 李华
网站建设 2026/5/3 6:25:50

Django Cookie/Session:深入理解与实践

Django Cookie/Session:深入理解与实践 引言 在Web开发中,Cookie和Session是两种常见的用户数据存储方式。它们在保持用户状态、实现个性化体验等方面发挥着重要作用。本文将深入探讨Django框架中的Cookie/Session机制,包括其原理、配置、使用方法以及注意事项。 Cookie/…

作者头像 李华