【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存储引擎层未过滤数据检查索引覆盖情况

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/70849.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何实现一个 Spring Boot Starter

在 Spring Boot 中,Starter 是一种自动配置的模块,它封装了一些常用的功能,并通过 Spring Boot 的约定大于配置的原则,使开发者能够快速使用和集成相关功能。通常,Spring Boot Starter 包含了所需的依赖、配置、自动化…

使用python做http代理请求

有这样一个需求现在有两台A,B两台电脑组成了一个局域网,在A电脑上开发webjava应用,需要调用第三方接口做http请求,但是这个请求只能在B电脑上请求。 一种解决方案:自定义一个中间服务,在电脑B上运行一个简…

系统架构设计师考点——嵌入式技术

一、备考指南 嵌入式技术主要考查的是嵌入式基础知识、嵌入式设计等相关知识,在系统架构设计师的考试中选择题占2~4分,案例分析有时会考关键路径的技术问答,这个题目一般比较难,但是由于案例分析题是五题选三题,所以…

当AI重构认知:技术狂潮下的教育沉思录

备注:文章未Deepseek R1模型辅助生成,如有不妥请谅解。 以下使原文: 我有三个娃,各间隔4到5岁,经历过搜索引擎,短视频,短剧,本身曾经也是教育专业出生,任何事务都有两面性…

EasyExcel 实践案例:打印工资条

文章目录 💡 1. 每个员工一个 Excel 文件✅ 占位符格式📌 Excel 模板📌 Java 代码🔥 关键点 💡 2. 每个员工一个 Sheet✅ 占位符格式📌 Java 代码🔥 关键点 💡 3. 一个 Sheet&#x…

编程题-从前序与中序遍历序列构造二叉树(中等-重点)

题目: 给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。 提示: preorder 和 inorder 均 无重复 元素 解法一(递归&#xff0…

Vue 3 + Vite 项目配置访问地址到服务器某个文件夹的解决方案

前言 在开发 Vue 3 Vite 项目时,我们经常需要将项目部署到服务器的某个特定文件夹下。例如,将项目部署到 /my-folder/ 目录下,而不是服务器的根目录。这时,我们需要对 Vite 和 Vue Router 进行一些配置,以确保项目能…

【Rust中级教程】2.10. API设计原则之受约束性(constrained) Pt.1:对类型进行修改、`#[non_exhaustive]`注解

喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文),对接下来的教程有兴趣的可以关注专栏。谢谢喵!(・ω・) 2.10.1. 接口的更改要三思 如果你的接口要做出对用户可见的更改,那么一定要三思…

Imagination GPU 3D Graphics Wrokload

本次分享Imagination GPU 的3D 图像处理负载流程。 总的分为两个阶段 第一阶段:Geometry Processing Phase(几何处理阶段)是渲染管线中的一个关键环节,主要负责对三维几何数据进行处理和变换,以便后续在屏幕上进行显…

自动化设备对接MES系统找DeepSeek问方案

项目需要现场的PLC设备HTTP协议JSON格式的方式对接MES系统平台,于是试了一下: 找到的相关资源链接在这里。

VoIP之音频3A技术

音频3A技术是改善语音通话质量的三种关键技术的简称,包括声学回声消除(Acoustic Echo Cancellation, AEC)、自动增益控制(Automatic Gain Control, AGC)、自噪声抑制(Automatic Noise Suppression, ANS&…

量子计算的数学基础:复数、矩阵和线性代数

量子计算是基于量子力学原理的一种新型计算模式,它与经典计算机在信息处理的方式上有着根本性的区别。在量子计算中,信息的最小单位是量子比特(qubit),而不是传统计算中的比特。量子比特的状态是通过量子力学中的数学工具来描述的,因此,理解量子计算的数学基础对于深入学…

京准电钟:NTP精密时钟服务器在自动化系统中的作用

京准电钟:NTP精密时钟服务器在自动化系统中的作用 京准电钟:NTP精密时钟服务器在自动化系统中的作用 NTP精密时钟服务器在自动化系统中的作用非常重要,特别是在需要高精度时间同步的场景中。NTP能够提供毫秒级的时间同步精度,这…

Python实现GO鹅优化算法优化Catboost回归模型项目实战

说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后关注获取。 1.项目背景 在当今的数据驱动时代,机器学习模型在各种应用中扮演着至关重要的角色。特别是在预测分…

如何在docker上部署前端nginx服务(VUE)

目录结构 clean.sh docker stop rszWeb; docker rm rszWeb; start.sh docker run -d \ --name rszWeb \ -p 7084:80 \ -m 500m \ --privileged=true \ --restart=always \ -v /home/rsz/ui/conf/nginx.conf:/etc/nginx/nginx.conf \ -v /home/rsz/ui/logs:/meta/logs \ -v /…

可狱可囚的爬虫系列课程 15:防盗链反爬虫的处理

一、防盗链了解 防盗链是一种技术手段,主要用于防止其他网站通过直接链接的方式使用本网站的资源(如图片、文件等),从而节省带宽和服务器资源。当其他网站尝试直接链接到受保护的资源时,服务器会根据设置的规则判断请求…

2020年蓝桥杯Java B组第二场题目+部分个人解析

#A&#xff1a;门牌制作 624 解一&#xff1a; public static void main(String[] args) {int count0;for(int i1;i<2020;i) {int ni;while(n>0) {if(n%102) {count;}n/10;}}System.out.println(count);} 解二&#xff1a; public static void main(String[] args) {…

Hadoop架构详解

Hadoop 是一个开源的分布式计算系统&#xff0c;用于存储和处理大规模数据集。Hadoop 主要由HDFS&#xff08;Hadoop Distributed File System&#xff09;、MapReduce、Yarn&#xff08;Jobtracker&#xff0c;TaskTracker&#xff09;三大核心组件组成。其中HDFS是分布式文件…

DeepSeek在初创企业、教育和数字营销领域应用思考

如今&#xff0c;像 DeepSeek 这样的人工智能工具正在改变企业的运营方式&#xff0c;优化流程并显著提高生产力。通过重复任务的自动化、大量数据的分析以及内容创建效率的提高&#xff0c;组织正在寻找新的竞争和卓越方式。本文介绍了 DeepSeek 如何用于提高三个关键领域的生…

day7作业

编写一个如下场景&#xff1a; 有一个英雄Hero类&#xff0c;私有成员&#xff0c;攻击&#xff08;Atx&#xff09;&#xff0c;防御&#xff08;Defense&#xff09;&#xff0c;速度&#xff08;Speed)&#xff0c;生命值&#xff08;Blood)&#xff0c;以及所有的set get 方…