MySQL Explain 分析 SQL 执行计划
在优化 SQL 查询性能时,了解查询的执行计划至关重要。MySQL 提供的 EXPLAIN 工具能够帮助我们深入了解查询语句的执行过程、索引使用情况以及潜在的性能瓶颈。
1. 什么是 EXPLAIN
EXPLAIN 是 MySQL 内置的分析工具,用于展示查询语句的执行计划。通过执行 EXPLAIN SELECT ...,我们可以获取关于查询如何访问表、使用哪些索引以及数据过滤过程的信息。借助这些信息,开发者能够针对性地优化查询和索引设计,从而提升查询性能。
2. EXPLAIN 输出的重要字段
当执行 EXPLAIN 语句时,MySQL 会返回一个结果集,包含多个字段。下面列出常见字段及其含义:
- id:查询中每个 SELECT 子句的标识符,值越大,优先级越高。对于复杂查询或嵌套查询,id 可以帮助识别各个子查询的执行顺序。
- select_type:查询的类型,例如 SIMPLE(简单查询)、PRIMARY(主查询)、SUBQUERY(子查询)等。了解查询类型有助于识别查询结构。
- table:显示当前访问的表名或别名。
- partitions:显示匹配的分区信息(如使用分区表时)。
- type:访问类型,是衡量查询效率的重要指标。常见值包括:
ALL:全表扫描,效率最低;index:全索引扫描;range:索引范围扫描;ref:非唯一索引查找;eq_ref、const:利用主键或唯一索引直接定位记录,效率最高。
- possible_keys:显示查询中可能用到的索引列表。
- key:实际使用的索引。如果此字段为 NULL,则表示没有使用索引。
- key_len:使用索引的字节长度,可帮助判断索引是否被充分利用。
- ref:显示索引匹配的列或常量,用于判断查询过滤条件。
- rows:预估需要扫描的行数,值越大代表查询代价越高。
- filtered:基于表中的数据过滤百分比,百分比越低表示需要过滤的数据量越大。
- Extra:补充信息,如
Using index(覆盖索引)、Using where(使用 WHERE 过滤条件)、Using temporary(使用临时表)、Using filesort(使用文件排序)等。特别注意Using temporary和Using filesort,它们通常表示查询中存在性能瓶颈。
3. 使用 EXPLAIN 分析查询
3.1 基本用法
只需在查询语句前加上 EXPLAIN 即可。例如:
EXPLAIN SELECT order_id, order_date, amount FROM orders WHERE customer_id = 1001;
执行后,你将获得一张表,展示 MySQL 如何解析和执行这条查询。
3.2 分析查询执行计划
- 检查访问类型(type):尽量避免 (全表扫描),推荐使用 、 或 。


