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/5 19:39:16

Python返回数组/List长度的方法

你想了解在 Python 中获取列表(List,也常被俗称 “数组”)长度的方法,这是 Python 基础中高频使用的操作,核心是通过内置函数实现,同时需要掌握不同场景下的使用细节(比如嵌套列表、numpy 数组等…

作者头像 李华
网站建设 2026/6/6 8:21:10

运维转行做什么好?零基础入门到精通,收藏这篇就够了

运维工程师转行网络安全是职业发展路径中比较常见的一种转行,这种转行通常基于以下几个原因和优势: **1.技能相关性:**运维工程师通常负责维护和管理企业的IT基础设施,包括服务器、网络和存储系统。这些工作内容与网络安全领域有…

作者头像 李华
网站建设 2026/6/6 6:46:06

XML 编码:深入解析与实际应用

XML 编码:深入解析与实际应用 引言 XML(可扩展标记语言)是一种用于存储和传输数据的标记语言。它被广泛应用于互联网、企业内部系统以及移动应用中。本文将深入解析XML编码的原理、规范以及在实际应用中的优势。 一、XML编码概述 1.1 XML的起源与发展 XML最早由W3C(万…

作者头像 李华
网站建设 2026/6/6 7:31:38

【Python基础】Python字符串操作全攻略:新手入门必备指南

目录 Python字符串操作全攻略:新手入门必备指南1. 引言:什么是字符串?2. 前置知识3. 字符串的创建与访问3.1 创建字符串3.2 访问字符串元素:索引和切片3.3 字符串的不可变性 4. 常用字符串操作方法4.1 获取字符串长度:…

作者头像 李华
网站建设 2026/6/8 22:45:03

全网十大降AI工具大比拼:知网、维普、万方实测数据公开

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

作者头像 李华
网站建设 2026/6/6 8:23:05

高效过审必备:盘点十大适合中国大学生的降AI工具

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

作者头像 李华