mysql执行sql语句优化分析命令explain命令小记
来源:互联网 发布:淘宝网对联宣纸 编辑:程序博客网 时间:2024/04/28 21:13
explain是用来分析sql语句,帮助优化的一个命令。她可以很详细的告诉你的sql语名出现的问题所在,以及是否用到索引。真的很好用。大家必须要会用哦!
explain的语法如下:
- explain [extended] select … from … where …
如果使用了extended,那么在执行完explain语句后,可以使用show warnings语句查询相应的优化信息。
比如我们执行 select uid from user where uname=’scofield’ order by uid 执行结果会有
+—-+————-+——-+——-+——————-+———+———+——-+——+——-+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+—-+————-+——-+——-+——————-+———+———+——-+——+——-+
这些东西。
其中 table 表示是哪个表的数据。
type比较重要。表示链接的类型。链接类型由好到坏的,依次是 system > const > eq_ref > ref > fulltext > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL
一般情况,至少要达到 range 级别,最好是 ref 级别。否则可能会有性能问题。
possible_keys 是指可以应用到该表的索引,如果为NULL则没有。
key 是指用到的索引。
key_len 是索引的长度,在不影响查询精度的情况下,值越小越好。
ref 是指索引的那一列被使用了。一般会是个常数。
rows 是指有多少行。
extra 是指额外的信息。也是比较重要的。如果值为 distinct ,说明MySQL 找到了域行联合匹配的行,就不再查找了。
如果值为 not exits : mysql优化了 left join ,一旦找到了 left join 匹配的行,便不再进行搜索了。
如果值为 rang checked for each : 没有找到理想的索引。
如果为 using filesort ,则需要改进sql了。这说明 mysql执行 需要 文件排序。这是比较影响效率的。
如果为 using temporary , 这是使用了 临时表。 这种情况也比较影响效率,sql需要改进。或者从应用层进行改进。
如果为 where used 说明使用了where语句。如果 type为 all 或者 index ,一般会出现这样的结果。这样的问题,一般是查询需要改进。
在一般稍大的系统中,基本尽可能的减少 join ,子查询 等等。mysql就使用最简单的查询,这样效率最高。至于 join 等,可以放在应用层去解决。- mysql执行sql语句优化分析命令explain命令小记
- mysql执行sql语句优化分析命令explain命令小记
- mysql优化–explain分析sql语句执行效率
- mysql优化–explain分析sql语句执行效率
- mySQL数据库Sql语句执行效率检查--Explain命令
- mySQL数据库Sql语句执行效率检查--Explain命令
- mySQL数据库Sql语句执行效率检查--Explain命令
- mySQL数据库Sql语句执行效率检查--Explain命令
- mySQL数据库Sql语句执行效率检查--Explain命令
- mySQL数据库Sql语句执行效率检查--Explain命令
- Explain命令查看MySQL的SQL语句执行效率
- mySQL数据库Sql语句执行效率检查--Explain命令
- mysql查询语句优化命令mysql explain
- 【mysql】mysql数据库Sql语句执行效率检查–Explain命令
- Mysql数据库Sql语句执行效率检查——Explain命令
- .mysql的SQL语句执行计划分析:EXPLAIN
- mysql explain分析sql语句的执行计划
- mysql的SQL语句执行计划分析:EXPLAIN
- 剑指Offer系列-面试题19:二叉树的镜像
- Canvas标签实现写字板功能
- 关于iOS页面中scrollview中嵌入百度地图滑动冲突问题解决方法
- 洛谷 1130_红pai_dp
- java 异常链
- mysql执行sql语句优化分析命令explain命令小记
- 智能物联网RTU数据采集终端在农田远程监测中的应用
- linux下jdk安装
- python import模块方法
- clip属性使用小Demo
- Java基础
- 增加信号处理的回射服务器
- django的makemigrations和migrate分别做了什么
- Linux下的内存分配方式简述