MYSQLLinux与后台开发归档

[MYSQL]explain 解释

2019-08-01  本文已影响0人  _小老虎_

1.select_type

2.type

3.key

MYSQL执行计划使用的索引

4.ref

和前方表连接的字段,const代表是常量值连接

5.rows

显示MYSQL执行查询的行数,简单且重要,数值越大越不好

6.extra

Distinct : 一旦MYSQL找到了与行相联合匹配的行,就不再搜索了

Range checked for each: 没有找到理想的索引,因此对于从前面表中来的每一个行组合,MYSQL检查使用哪个索引,并用它来从表中返回行。这是使用索引的最慢的连接之一

Using filesort: 发生了硬盘或内存排序,一般是由order by 或 group by触发的;典型的情况,排序的字段不是驱动表的字段,则会使用临时表将数据都添加进去,最后进行排序,如果数据大则硬盘排序,如果小则内存排序.

Using index :列数据是从仅仅使用了索引中的信息而没有读取实际的行动的表返回的,使用了覆盖索引优化

Using temporary :使用了临时表,通常和filesort一起发生. 典型情况:使用了派生表.

Using where: 数据库服务层从存储引擎提取了数据又进行了一次条件过滤

using index condition: ICP优化,从5.6之后提供.将过滤条件下推到存储引擎层执行,能更好的利用复合索引来过滤数据,减少IO.

Using index for group-by:使用了松散索引扫描

上一篇 下一篇

猜你喜欢

热点阅读