时间:2021-05-02
在MySQL性能调优的时候explain是必须要使用的关键字,它的作用是可以查看sql语句的执行信息,包括表的读取顺序,应用到的索引等信息。
用法:explain + sql语句。
本篇我们先熟悉explain的内容,为下篇学习索引奠定基础。
explain内容
查看user全表查询的执行计划:
mysql>explainselect*fromuser;
id
id表示select查询语句的执行顺序或者是操作表的执行顺序。
id的值有二种情况:
select_type
select_type表示查询类型,它的值域为:SIMPLE、PRIMARY、SUBQUERY、DERIVED、UNION、UNION RESULT。
table
数据行是从哪个表获取的。
type
表示查询使用了哪种类型,它的值域:ALL、index、range、ref、eq_ref、const、system。这是我们优化时重点关注的一个指标。
从最好到最差排序:
system>const>eq_ref>ref>range>index>ALL。
阿里巴巴SQL优化规范:
system:表中只有一行记录的查询,类似系统表。
eq_ref:多表时唯一索引扫描,对于每一个索引,表中只有一行记录相匹配。
index:索引物理文件全扫描,速度比较慢,比全表扫描性能好一点。
ALL:全表扫描。
possible_keys
可能应用在这个表的索引,可以会一个或者多个,不一定是实际查询使用的索引。
key
查询中实际使用的索引,如果为null表示没有使用索引。
如果是覆盖索引,则只显示在key中。
key_len
表示索引字段的最大可能长度,并不是实际的长度,它是根据表定义得到的,而不是通过表检索得到的。长度越短越好。
ref
表示索引的哪一列被使用了,可能是个常数。哪些列或者常量被用于查找索引列上的值。
rows
根据表的信息和索引使用情况,大致估算的查找到所需的记录需要扫描的行数。越小越好。
Extra
扩展信息。
阿里巴巴SQL优化规范:
这里提到了覆盖索引,extra列会出现using index。
extra还有其他比较重要的信息:
using filesort:用到了外部的索引排序,即MySQL无法利用索引完成排序。
using temptory:使用了临时表。
using where:使用了where过滤。
还有其他几种,不是经常出现,我们就不说明了。
原文地址:https://www.toutiao.com/i6937641430135685646/
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
explain用于获取查询执行计划信息,一、语法只需要在select前加上explain即可,如:mysql>explainselect1;+----+----
索引相关1.查询(或更新,删除,可以转换为查询)没有用到索引这是最基础的步骤,需要对sql执行explain查看执行计划中是否用到了索引,需要重点关注type=
MySQL的EXPLAIN命令用于SQL语句的查询执行计划(QEP)。这条命令的输出结果能够让我们了解MySQL优化器是如何执行SQL语句的。这条命令并没有提供
1.使用EXPLAINEXPLAIN命令可以查看执行计划,在前面的blog中已经介绍过。这个方法是我们最主要的调试工具。2.及时更新执行计划中使用的统计信息由于
我们知道分析MySQL语句查询性能的方法除了使用EXPLAIN输出执行计划,还可以让MySQL记录下查询超过指定时间的语句,我们将超过指定时间的SQL语句查询称