MySQL优化器在基于成本的计算和基于规则的SQL优化会生成一个所谓的执行计划,我们就可以使用执行计划查看MySQL对该语句具体的执行方式。
介绍这个好啰嗦就是了,我们可以通过这个优化器展示的执行计划,查看优化器对我们的SQL进行优化的步骤,连接转换成单表访问时的优化。以及对于之前知识的复习了属于是,比如访问方式,索引的选择,半连接等SQL语句优化。
mysql> explain select * from mall.ums_admin; +----+-------------+-----------+------------+------+---------------+------+---------+------+------+----------+-------+ | id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra | +----+-------------+-----------+------------+------+---------------+------+---------+------+------+----------+-------+ | 1 | SIMPLE | ums_admin | NULL | ALL | NULL | NULL | NULL | NULL | 5 | 100.00 | NULL | +----+-------------+-----------+------------+------+---------------+------+---------+------+------+----------+-------+ 1 row in set, 1 warning (0.00 sec)
上述是我们使用explain使用的简单小例子。下面是每列的简单描述。
我们接下来就是对于Explain中展示的列进行介绍,回涉及到之前的SQL成本和语句优化。
对于每个SQL语句来说,不管是不是使用连接的多表查询,我们最后都会变成执行多个单表查询的语句。所以table列就指明了当前执行某个计划的表是哪一个。就比如上面例子的单表查询的SQL。
会有以下几种情况
单表查询,此时的ID列就为1。
连接查询,此时对于两个表的连接查询ID列都为1,MySQL视在前面的表就是作为驱动表,在后面的表就是作为被驱动表。
子查询,有多种情况
UNION连表,就是出现一个select就再分配一个ID值。稍微有点特殊对于UNION ALL。
首先呢是因为UNION关键字会对合并的结果集进行去重,进行去重就得创建一个临时表来进行去重,第三行是一个临时表。但是呢UNION ALL不去重就不会出现第三行记录。
就是简单的单表查询或者连接查询。
就是UNION或UNION ALL或子查询的情况下,最左边的select就是PRIMARY类型的。
就是UNION的时候除了最左边的SELECT是PRIMARY类型,其他的SELECT都是UNION。
UNION的结果就会创建一个临时表进行去重,临时表就是这个select_type。
以上三个条件成立,此时子查询的第一个select部分的select_type就是SUBQUERY。如果物化的话,子查询只会执行一次,应该不用多说了。
以上条件成立,此时子查询的第一个select部分的select_type就是DEPENDENT SUBQUERY。相关外层查询会不断传参然后一直进行子查询。
UNION中除了最左边的select部分,被union连接的小查询的select_type 都是DEPENDENT UNION。
采用物化的方式执行的派生表,其中的子查询的select_type就是DERIVED。
当子查询是物化后转连接的方式,就是首先子查询是不相关子查询,然后子查询执行物化,优化成连接的方式和外层查询。此时子查询的select_type就是MATERIALIZED。
一般情况下都为null。
就是介绍访问当前行的表的访问方式。
我们之前学习的有
新的
possible_key就是SQL可以用到的索引。
key就是优化器计算成本后决定使用的索引列。
就是使用的索引的索引记录的长度。有三部分相加而成。
对于上面三部分,前面已经讲得很清楚了。
如果是varchar(100)可以为null的列,就需要300字节数据最大长度+1字节的非null+2字节记录长度,总长度就是303字节。
对于联合索引来说,用几个索引这个值就根据索引进行叠加上去,606就是俩varchar(100)可以为null的字段的联合索引。
就是当我们使用索引进行匹配的时候,索引列具体等值匹配的是什么东西,常数值还是一个列等等。
代表优化器经过预测具体要扫描表或者索引多少行。
代表驱动表的扇出比例,比如驱动表经过自身查询条件后预计会有多少记录数符合条件,输出出来。
对于单表来说这个字段没有意义,但是对于连接查询来说,可以预计被驱动表会执行多少次,即驱动表的扇出值。
就是优化器为我们提供额外信息,来帮助我们分析语句。
No tables used
Impossible where
No matching min/max row
Using index
Using index condition
Using where
Using join buffer
Not exists
Using intersect(...) ,Using union(...),Using sort_union(...)
Zero limit
Using filesort
Using temporary
Start temporary , End temporary
LooseScan
FirstMatch