MySQL 中如何查看 SQL 的执行计划?

server/2025/2/27 20:26:26/

SQL 语句前面使用 EXPLAIN 关键字:

EXPLAIN SELECT * FROM users WHERE id = 1;

字段

含义

id

查询的序号(如果是子查询或联合查询,会有多个 id)。

select_type

查询的类型(简单查询、子查询、联合查询等)。

table

查询涉及的表名。

partitions

查询时使用的分区(如果表有分区)。

type

查询的访问类型(性能从高到低:system> const> eq_ref> ref> range> index> ALL)。

possible_keys

可能使用的索引。

key

实际使用的索引。

key_len

使用的索引长度。

ref

使用的索引与哪些列或常量进行比较。

rows

估算的扫描行数。

filtered

计算结果集占扫描行数的百分比(MySQL 5.7+)。

Extra

额外信息(如 Using whereUsing indexUsing temporary 等)。


EXPLAIN 的关键字段详解

type:表示 MySQL 如何访问数据,性能从高到低排序。

  • system:表中只有一行数据(系统表)。
  • const:通过主键或唯一索引查询,结果只有一行。
  • eq_ref:在连接查询中,主键或唯一索引被使用,返回最多一行。
  • ref:使用非唯一索引查询,返回匹配的多行。
  • range:使用索引进行范围查询(如 BETWEENIN)。
  • index:全索引扫描(比全表扫描快,但仍需遍历索引)。
  • ALL:全表扫描(性能最差)。

Extra:提供查询的额外信息

  • Using where:查询使用了 WHERE 条件。
  • Using index:使用了覆盖索引(无需回表)。
  • Using temporary:使用了临时表(常见于排序或分组)。
  • Using filesort:使用了文件排序(性能较低)。
  • Using join buffer:使用了连接缓存(多表连接时)。

如何分析 EXPLAIN 结果

通过 EXPLAIN 结果,可以优化查询:

1.检查 type

  • 目标是使用 consteq_refrefrange
  • 避免 ALL(全表扫描)。

2.检查 key

    • 确保查询使用了索引。
    • 如果没有使用索引,考虑添加合适的索引。

3.检查 rows

  • 估算的扫描行数越少越好。
  • 如果行数过多,优化查询条件或索引。

4.检查 Extra

  • 避免 Using temporaryUsing filesort
  • 尽量使用 Using index

水平有限,如有错误,欢迎指正!


http://www.ppmy.cn/server/171118.html

相关文章

linux清理方法

本文适用于初学者,主要针对linux学习过程中遇到的内存不足的问题。 一.大文件排除法 使用find命令直接查找所有大于1G的文件。 find / -type f -size 1G 得到所有目标文件后,逐一进行排查,删除不需要的文件,如已经解压过的安装…

内存泄漏问题分享

在前端开发中,内存泄漏(Memory Leak)是指由于代码问题导致浏览器无法回收不再使用的内存,从而影响网页的性能,导致页面变慢,甚至崩溃。前端内存泄漏通常由以下几种原因引起,理解和修复这些问题对…

纷析云:赋能企业财务数字化转型的开源解决方案

在企业数字化转型的浪潮中,财务管理的高效与安全成为关键。纷析云凭借其开源、安全、灵活的财务软件解决方案,为企业提供了一条理想的转型路径。 一、开源的力量:自主、安全、高效 纷析云的核心优势在于其100%开源的财务软件源码。这意味着…

Docker 与 Serverless(无服务器架构)

Serverless(无服务器架构) 是一种新的云计算架构,它通过让开发者专注于业务逻辑而无需管理服务器基础设施,来简化应用的开发和部署。Serverless 模型通常由云服务提供商管理基础设施的所有方面,而开发者只需提供代码和…

2025年02月24日Github流行趋势

项目名称:mastra 项目地址url:https://github.com/mastra-ai/mastra 项目语言:TypeScript 历史star数:5735 今日star数:1140 项目维护者:adeleke5140, abhiaiyer91, TheIsrael1, adeniyii, Joshuafolorunsh…

形式化数学编程在AI医疗中的探索路径分析

一、引言 1.1 研究背景与意义 在数字化时代,形式化数学编程和 AI 形式化医疗作为前沿领域,正逐渐改变着我们的生活和医疗模式。形式化数学编程是一种运用数学逻辑和严格的形式化语言来描述和验证程序的技术,它通过数学的精确性和逻辑性,确保程序的正确性和可靠性。在软件…

Spark内存迭代计算

一、宽窄依赖 窄依赖:父RDD的一个分区数据全部发往子RDD的一个分区 宽依赖:父RDD的一个分区数据发往子RDD的多个分区,也称为shuffle 二、Spark是如何进行内存计算的?DAG的作用?Stage阶段划分的作用? &a…

OA办公系统自动渗透测试过程

目录 一、下载环境源码 二、部署环境 三、测试 XSS漏洞 SQL注入 文件上传漏洞 一、下载环境源码 OA源码打包地址: https://download.csdn.net/download/weixin_43650289/90434502?spm=1001.2014.3001.5503 二、部署环境