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

【MySql】EXPLAIN执行计划全解析:15个字段深度解读与调优指南

文章目录

    • 一、执行计划核心字段总览
    • 二、关键字段深度拆解
      • 1. type(访问类型)——查询性能的晴雨表
        • 典型场景分析:
      • 2. key_len(索引使用长度)——索引利用率的检测仪
        • 计算示例:
      • 3. Extra(附加信息)——隐藏的性能杀手
        • 常见值解析:
    • 三、全字段详解速查表
    • 四、性能诊断四步法
      • 第一步:检查type等级
      • 第二步:验证索引使用
      • 第三步:分析扫描行数
      • 第四步:排查Extra警告
    • 五、经典优化案例
      • 案例1:索引失效分析
      • 案例2:覆盖索引优化
    • 六、高级分析技巧
      • 1. JSON格式查看详细成本
      • 2. 索引长度验证公式
      • 3. 执行计划可视化工具推荐
    • 七、常见问题解决方案

一、执行计划核心字段总览

在这里插入图片描述

字段名人类语言解释性能影响等级
type数据访问方式★★★★★
key实际使用索引★★★★☆
rows预估扫描行数★★★★☆
Extra附加执行信息★★★★☆
key_len使用索引的长度★★★☆☆

二、关键字段深度拆解

1. type(访问类型)——查询性能的晴雨表

性能从优到劣排序
system > const > eq_ref > ref > fulltext > range > index > ALL

典型场景分析:
-- 最优情况:主键查询
EXPLAIN SELECT * FROM users WHERE id = 1;
-- type: const

-- 最差情况:全表扫描
EXPLAIN SELECT * FROM orders WHERE amount > 100;
-- type: ALL

2. key_len(索引使用长度)——索引利用率的检测仪

计算公式
索引字段长度 × 字段数 + 预留字节

计算示例:
CREATE TABLE `demo` (
  `id` INT(11) NOT NULL,
  `name` VARCHAR(20) DEFAULT NULL,
  `age` TINYINT(4) DEFAULT NULL,
  INDEX `idx_name_age` (`name`,`age`)
);

-- 查询1:使用完整索引
EXPLAIN SELECT * FROM demo WHERE name='张三' AND age=25;
-- key_len = 20*3+1 + 1 = 62

-- 查询2:仅使用name列
EXPLAIN SELECT * FROM demo WHERE name='李四';
-- key_len = 20*3+1 = 61

3. Extra(附加信息)——隐藏的性能杀手

常见值解析:
含义处理建议
Using index使用覆盖索引保持当前优化
Using temporary使用临时表检查GROUP BY/ORDER BY字段
Using filesort文件排序添加合适索引
Using where存储引擎返回后过滤检查索引是否完整
Select tables optimized away优化器已优化(如MIN/MAX查询)无需处理

三、全字段详解速查表

字段名含义常见值示例
id查询序列号1, 2(联合查询时数值不同)
select_type查询类型SIMPLE, PRIMARY, SUBQUERY
table访问的表名users, orders
partitions匹配的分区p0, p1
type访问方式const, ref, ALL
possible_keys可能使用的索引idx_name, PRIMARY
key实际使用的索引idx_age
key_len使用索引的长度4, 62
ref索引引用关系const, db1.users.id
rows预估扫描行数1, 10024
filtered存储引擎返回数据后,经过过滤剩余的比例100.00
Extra附加执行信息Using index, Using temporary

四、性能诊断四步法

第一步:检查type等级

- ✅ 目标:至少达到range级别
- ❌ 问题:出现ALL时需要紧急优化
- 💡 处理:添加合适索引

第二步:验证索引使用

-- 检查实际使用索引是否最优
SHOW INDEX FROM users;

第三步:分析扫描行数

- 当rows > 10000时:可能存在全表扫描
- 优化案例:100万行表查询从2s优化到0.02s

第四步:排查Extra警告

1. 发现Using filesort → 检查ORDER BY字段是否匹配索引
2. 出现Using temporary → 优化GROUP BY字段
3. 存在Using where → 检查查询条件是否完整使用索引

五、经典优化案例

案例1:索引失效分析

-- 原始查询(type: ALL)
EXPLAIN SELECT * FROM orders WHERE YEAR(create_time)=2023;

-- 优化方案:改为范围查询
EXPLAIN SELECT * FROM orders 
WHERE create_time BETWEEN '2023-01-01' AND '2023-12-31';
-- type提升为range

案例2:覆盖索引优化

-- 原始查询(Extra: NULL)
EXPLAIN SELECT user_id FROM comments WHERE post_id=100;

-- 创建覆盖索引
ALTER TABLE comments ADD INDEX idx_post_user(post_id,user_id);
-- Extra显示Using index

六、高级分析技巧

1. JSON格式查看详细成本

EXPLAIN FORMAT=JSON 
SELECT * FROM products WHERE price > 100;
-- 查看"cost_info"字段

2. 索引长度验证公式

VARCHAR(n):n*3+2
INT:4
TINYINT:1
DATETIME:5
允许NULL的字段:+1

3. 执行计划可视化工具推荐

  1. MySQL Workbench执行计划可视化
  2. Percona Toolkit的pt-visual-explain
  3. JetBrains DataGrip的图形化展示

七、常见问题解决方案

症状原因解决方案
type=ALL无可用索引添加WHERE条件涉及的索引
Using filesort排序字段不匹配索引创建复合索引包含排序字段
key_len过短未充分使用复合索引检查查询条件顺序
rows数值异常统计信息过期执行ANALYZE TABLE
filtered=100存储引擎层未过滤数据检查索引覆盖情况

相关文章:

  • 【深度学习】PyTorch v2.6 Overview
  • 设计后端返回给前端的返回体
  • 钉钉MAKE AI生态大会思考
  • C++ | 高级教程 | 泛型模板
  • 数据结构秘籍(一)线性数据结构
  • 注意力机制有哪些,原理是什么
  • 细说STM32F407单片机RS485收发通信实例及调试方法
  • wordpress使用CorePress主题设置项总结
  • Elasticsearch:使用经过训练的 ML 模型理解稀疏向量嵌入
  • Python Pandas带多组参数和标签的Oracle数据库批量数据导出程序
  • MySQL-MATCH ... AGAINST工具
  • linux--多进程开发(5)--进程间通信(IPC)、linux间通信的方式、管道
  • 全价值链数字化转型:以美的集团为例,探索开源AI大模型与S2B2C商城小程序源码的融合应用
  • MySQL之Redo Log:确保数据持久性和崩溃恢复
  • MySql 获取表结构的4中方法
  • 【如何优化 Vue.js 项目的性能?】
  • mfy学习笔记
  • C# 数据类型
  • C#异步编程之async与await
  • sklearn机器学习 Python代码通用模板
  • 奢侈品网站策划方案/杭州网站seo外包
  • 别人做的网站域名到期怎么办/培训网站
  • 查询网站是否备案/短视频培训学校
  • 广东深圳疫情最新/seo按照搜索引擎的什么对网站
  • 漫画驿站网页设计图纸尺寸图/网上开店如何推广自己的网店
  • 哈尔滨网站设计/广州外贸推广