news 2026/6/9 20:07:33

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/6/9 16:30:11

第P3周:Pytorch实现天气识别

🍨 本文为🔗365天深度学习训练营中的学习记录博客 🍖 原作者:K同学啊 目录 一、 前期准备 1. 设置GPU 2. 导入数据 3. 显示图片 4. 划分数据集 二、构建简单的CNN网络 三、 训练模型 1. 设置超参数 2. 编写训练函数 3. …

作者头像 李华
网站建设 2026/5/30 21:24:29

学术圈公认最好用的十大降ai率产品全测评

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

作者头像 李华
网站建设 2026/6/7 4:48:06

企业数据API对接稳定性挑战与高可用架构实践指南

在数字化转型浪潮席卷全球的今天,企业数据API(Application Programming Interface)已成为连接内部系统、第三方服务与合作伙伴生态的核心纽带。然而,随着API调用量的指数级增长,企业面临着严峻的技术挑战:A…

作者头像 李华
网站建设 2026/6/9 18:52:37

通信协议仿真:5G NR协议仿真_(12).5G NR仿真中的移动性管理

5G NR仿真中的移动性管理 1. 移动性管理概述 移动性管理是5G NR(New Radio)协议中的一个重要组成部分,它确保用户在移动过程中能够保持无缝的连接和服务质量。移动性管理涉及多个方面,包括小区选择与重选、切换、重定向、连接恢复…

作者头像 李华
网站建设 2026/6/5 23:03:41

Chart.js 极地图

Chart.js 极地图 引言 极地图(Polar Chart)是一种展示数据分布和关系的图表类型,它通过极坐标系统来展示数据。在众多图表库中,Chart.js 是一个功能强大且易于使用的 JavaScript 图表库。本文将详细介绍如何使用 Chart.js 创建极地图,并探讨其在数据可视化中的应用。 极…

作者头像 李华
网站建设 2026/6/6 11:35:57

只要十分钟,AI率从89%降到13%!2025年度十大降AI工具推荐

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

作者头像 李华