MySQL查询优化之explain详解
2017-07-27 09:56
507 查看
MySQL explain命令显示了mysql如何使用索引来处理select语句以及连接表。可以帮助选择更好的索引和写出更优化的查询语句。
使用方法,在select语句前加上explain就可以了:
EXPLAIN 列的解释:
id
SELECT识别符。这是SELECT查询序列号。这个不重要,查询序号即为sql语句执行的顺序。
select_type
表示查询的类型:
table
对应行正在访问哪一个表,表名或者别名.
type
type显示的是访问类型,是较为重要的一个指标,结果值从好到坏依次是:
system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL ,一般来说,得保证查询至少达到range级别,最好能达到ref。
possible_keys
显示查询使用了哪些索引,表示该索引可以进行高效地查找,但是列出来的索引对于后续优化过程可能是没有用的.
key
key列显示MySQL实际决定使用的键(索引)。如果没有选择索引,键是NULL。要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。
key_len
key_len列显示MySQL决定使用的键长度。如果键是NULL,则长度为NULL。使用的索引的长度。在不损失精确性的情况下,长度越短越好
ref
哪一列或常数在查询中与索引键列一起使用
rows
rows列显示MySQL认为它执行查询时必须检查的行数。注意这是一个预估值。
Extra
Extra是EXPLAIN输出中另外一个很重要的列,该列显示MySQL在查询过程中的一些详细信息,MySQL查询优化器执行查询的过程中对查询计划的重要补充信息。
参考文档:https://mp.weixin.qq.com/s/q2CxOEEVGW7IYXeP_wE_wQ
使用方法,在select语句前加上explain就可以了:
mysql> explain select * from hb_cc where name='kk'\G *************************** 1. row *************************** id: 1 select_type: SIMPLE table: hb_cc type: ALL possible_keys: NULL key: NULL key_len: NULL ref: NULL rows: 2 Extra: Using where 1 row in set (0.00 sec) mysql>
EXPLAIN 列的解释:
id
SELECT识别符。这是SELECT查询序列号。这个不重要,查询序号即为sql语句执行的顺序。
select_type
表示查询的类型:
table
对应行正在访问哪一个表,表名或者别名.
type
type显示的是访问类型,是较为重要的一个指标,结果值从好到坏依次是:
system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL ,一般来说,得保证查询至少达到range级别,最好能达到ref。
possible_keys
显示查询使用了哪些索引,表示该索引可以进行高效地查找,但是列出来的索引对于后续优化过程可能是没有用的.
key
key列显示MySQL实际决定使用的键(索引)。如果没有选择索引,键是NULL。要想强制MySQL使用或忽视possible_keys列中的索引,在查询中使用FORCE INDEX、USE INDEX或者IGNORE INDEX。
key_len
key_len列显示MySQL决定使用的键长度。如果键是NULL,则长度为NULL。使用的索引的长度。在不损失精确性的情况下,长度越短越好
ref
哪一列或常数在查询中与索引键列一起使用
rows
rows列显示MySQL认为它执行查询时必须检查的行数。注意这是一个预估值。
Extra
Extra是EXPLAIN输出中另外一个很重要的列,该列显示MySQL在查询过程中的一些详细信息,MySQL查询优化器执行查询的过程中对查询计划的重要补充信息。
参考文档:https://mp.weixin.qq.com/s/q2CxOEEVGW7IYXeP_wE_wQ
相关文章推荐
- MySQL表查询优化(一):妙用explain中的type指标
- MySQL查询优化之explain的深入解析
- MySQL查询优化之explain的深入解析
- Mysql查询性能优化-善用Explain语句
- MySQL查询优化之explain的深入解析
- 详解Mysql多表联合查询效率分析及优化
- 详解Mysql多表联合查询效率分析及优化
- 【MySQL笔记】SQL优化利器 - explain命令的输出格式详解
- 优化mysql实验(explain;索引)+利用 index、explain和profile优化mysql数据库查询小结
- mysql查询时offset过大影响性能的原因和优化详解
- MySQL查询优化-explain
- mysql:21个性能优化最佳实践之2[EXPLAIN 你的 SELECT 查询]
- MySQL查询优化之explain的深入解析
- 用MySql的查询分析语法explain来优化查询和索引
- MySQL查询优化之explain的深入解析
- MySQL查询优化之索引的应用详解
- MySQL查询优化-explain
- MySQL查询优化-explain