MySql中如何使用 explain 查询 SQL 的执行计划
explain命令是查看查询优化器如何决定执行查询的主要方法。
这个功能有局限性,并不总会说出真相,但它的输出是可以获取的最好信息,值得花时间去了解,因为可以学习到查询是如何执行的。
1、什么是mysql执行计划
要对执行计划有个比较好的理解,需要先对mysql的基础结构及查询基本原理有简单的了解。
mysql本身的功能架构分为三个部分,分别是 应用层、逻辑层、物理层,不只是mysql ,其他大多数数据库产品都是按这种架构来进行划分的。
应用层,主要负责与客户端进行交互,建立链接,记住链接状态,返回数据,响应请求,这一层是和客户端打交道的。
逻辑层,主要负责查询处理、事务管理等其他数据库功能处理,以查询为例。
首先接收到查询sql之后,数据库会立即分配一个线程对其进行处理,第一步查询处理器会对sql查询进行优化,优化后会生成执行计划,然后交由计划执行器来执行。
计划执行器需要访问更底层的事务管理器,存储管理器来操作数据,他们各自的分工各有不同,最终通过调用物理层的文件获取到查询结构信息,将最终结果响应给应用层。
物理层,实际物理磁盘上存储的文件,主要有分文数据文件,日志文件。
通过上面的描述,生成执行计划是执行一条sql必不可少的步骤,一条sql性能的好坏,可以通过查看执行计划很直观的看出来,执行计划提供了各种查询类型与级别,方面我们进行查看以及为作为性能分析的依据。
2、如何分析执行计划
mysql为我们提供了 explain 关键字来直观的查看一条sql的执行计划。
explain显示了mysql如何使用索引来处理select语句以及连接表,可以帮助选择更好的索引和写出更优化的查询语句。
下面我们使用 explain 做一个查询,如下:
mysql> explain select * from payment; +----+-------------+---------+------------+------+---------------+------+---------+------+-------+----------+-------+ | id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | extra | +----+-------------+---------+------------+------+---------------+------+---------+------+-------+----------+-------+ | 1 | simple | payment | null | all | null | null | null | null | 16086 | 100.00 | null | +----+-------------+---------+------------+------+---------------+------+---------+------+-------+----------+-------+ 1 row in set, 1 warning (0.01 sec)
查询结构中有12列,理解每一列的含义,对理解执行计划至关重要,下面用一个表格的形式进行说明。
列名 | 说明 |
---|---|
id | select识别符,这是select的查询序列号。 |
select_type |
select类型,可以为以下任何一种:
|
table | 输出的行所引用的表 |
partitions | 如果查询是基于分区表的话,显示查询将访问的分区。 |
type |
联接类型。下面给出各种联接类型,按照从最佳类型到最坏类型进行排序:
一般来说,得保证查询至少达到range级别,最好能达到ref。 |
possible_keys | 指出mysql能使用哪个索引在该表中找到行 |
key | 显示mysql实际决定使用的键(索引)。如果没有选择索引,键是null。 |
key_len | 显示mysql决定使用的键长度。如果键是null,则长度为null。在不损失精确性的情况下,长度越短越好 |
ref | 显示使用哪个列或常数与key一起从表中选择行。 |
rows | 显示mysql认为它执行查询时必须检查的行数。多行之间的数据相乘可以估算要处理的行数。 |
filtered | 显示了通过条件过滤出的行数的百分比估计值。 |
extra |
该列包含mysql解决查询的详细信息
|
总结
以上所述是小编给大家介绍的mysql中如何使用 explain 查询 sql 的执行计划,希望对大家有所帮助
上一篇: MySQL用户权限验证与管理方法详解
下一篇: SpringBoot启动过程的实现
推荐阅读
-
Mysql中SQL语句不使用索引的情况
-
MySQL中通过EXPLAIN如何分析SQL的执行计划详解
-
PHP使用mysql_fetch_object从查询结果中获取对象集的方法
-
mysql实战45讲读书笔记(一) 一条SQL查询语句是如何执行的
-
强制SQL Server执行计划使用并行提升在复杂查询语句下的性能
-
SQL Server查询条件IN中能否使用变量的示例详解
-
mysql 使用group by报错 sql_mode=only_full_group_by 在navicat中修改session 中的sql_mode
-
SQL如何实现MYSQL的递归查询
-
使用distinct在mysql中查询多条不重复记录值的解决办法
-
如何让docker中的mysql启动时自动执行sql语句