MySQLSQL极简教程 · MySQL · MyBatis · JPA 技术笔记 教程 总结mysql

数据库练习三: 认识Explain

2018-06-16  本文已影响23人  蓝汝丶琪

介绍

EXPLAIN命令是查询性能优化不可缺少的一部分。
使用explain关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是如何处理你的SQL语句的,分析你的查询语句或是表结构的性能瓶颈。

先来查看一下Explain 语句。

语句:

explain select * from employees;
image.png

其中最重要的字段为:id、type、key、rows、Extra

接下来 解析一下每个字段的含义

  1. id
EXPLAIN  select concat(e.first_name,' ',last_name) `name` ,salary  from
    employees as e , salaries as sa where
    e.emp_no=sa.emp_no  and
    sa.salary= 
    (select min(salary)  from salaries);
image.png

执行顺序为 salaries->sa->e

  1. select_type
    查询的类型,主要是用于区分普通查询、联合查询、子查询等复杂的查询
  1. type
    type 字段比较重要,它提供了判断查询是否高效的重要依据依据。 通过 type 字段,我们判断此次查询是 全表扫描 还是 索引扫描等。

例子:
从第一点的图可以看到。


image.png

第一条和第三条,type 都是ALL,说明效率是很差,需要优化了。

效率好坏:

ALL < index < range ~ index_merge < ref < eq_ref < const < system

字段介绍:

一般来说,好的sql查询至少达到range级别,最好能达到ref

  1. possible_keys
    它表示 mysql 在查询时,可能使用到的索引。 注意,即使有些索引在 possible_keys 中出现,但是并不表示此索引会真正地被 mysql 使用到。 mysql 在查询时具体使用了哪些索引,由 key 字段决定。

  2. key
    重要字段
    此字段是 mysql 在当前查询时所真正使用到的索引。

    image.png

看第一条,possible_keys是主键,但key却为空,说明在实际查询中,并没有用上该索引。

  1. key_len
    表示查询优化器使用了索引的字节数,这个字段可以评估组合索引是否完全被使用

  2. ref
    显示索引的那一列被使用了,如果可能,是一个常量const。

  3. rows
    重要字段
    mysql 查询优化器根据统计信息,估算 sql 要查找到结果集需要扫描读取的数据行数,这个值非常直观的显示 sql 效率好坏, 原则上 rows 越少越好。

  4. extra
    重要字段
    explain 中的很多额外的信息会在 extra 字段显示

上一篇 下一篇

猜你喜欢

热点阅读