mysql--explain分析
来源:互联网 发布:看京剧的软件 编辑:程序博客网 时间:2024/06/07 18:05
如果你发现一条sql语句执行的特别慢时,你会怎么做呢?mysql中我们可以使用explain来分析sql的执行效率。那么在使用之前,先来了解一下如何查看执行explain后,给我们的分析结果。
先来看一个例子吧,这样可以有一个宏观的认识。
查看分析结果,发现上图中列出了很多项分析,我们逐个了解各个含义。
1、id
数据库为执行的sql语句进行的编号,这个对我们分析来说不重要。
2、select_type
查询类型。主要有两大类,一个是Simple(不含子查询),Primary(复杂查询),下面一张图能够说明这几种查询的关系。
3、talbe
查询针对的表。
有可能是表的别名;如果为null,则表示直接计算的结果,不用查表
4、possible key
可能用到的索引
注:系统估计可能用到几个索引,但最终执行时只用一个索引
5、key
最终使用的索引
6、key_len
使用的索引的最大长度
7、type
查询的方式,是分析“查询数据过程”的重要依据的值。有一下几种类型:
1)all:
意味着从表的第1行往后逐行做全表扫描
2)index:
比all性能好一点,all扫描所有的行数,index扫描所有的索引节点
3)range:
查询时能根据索引做范围的扫描
4)ref:
通过索隐裂,可直接引用到某些数据行
5)eq_ref:
通过索引列,直接引用某一行数据
6)constant、system、null
这三个分别指查询优化到常量级别,甚至不需要查找时间
8、ref:
连接查询时,前表与后表的引用关系
9、rows:
估计扫描多少行
10、extra:
index: 是指用到了索引覆盖,效率非常高
using where 是指光靠索引定位不了,还得where判断一下
using temporary 是指用上了临时表, group by与order by 不同列时,或group by ,order by 别的表的列.
using filesort : 文件排序(文件可能在磁盘,也可能在内存)
- Mysql分析-explain
- mysql explain分析
- mysql explain 的分析
- mysql--explain分析
- mysql 查询语句分析explain
- MySQL性能分析及explain
- MySQL性能分析及explain
- MySql 使用explain分析查询
- mysql——explain分析
- MySQL利用explain来分析
- mysql 性能分析及explain分析
- mysql profile explain slow_query_log分析优化查询
- MySQL性能分析命令:Explain 详解
- mysql 性能分析及explain用法
- mysql 性能分析及explain用法
- Mysql explain用法和性能分析
- MySQL性能分析及explain的使用
- Mysql explain用法和性能分析
- JVM垃圾回收机制与内存回收
- 对链表排序
- Java 基础【01】 This 用法
- 微信小程序 五 下拉刷新
- X79-UD5 BIOS
- mysql--explain分析
- 工程师文化见解一二
- 使用VB操作Excel(随笔记录)
- 深度学习在推荐领域的应用
- 浅谈HTTP中Get与Post的区别
- 安装JDK出现问题 Error opening registry key'software\Javasoft\Java Runtime Environment'
- 小强学Python+OpenCV之-1.4.5通道拆分(cv2.split)及合并(cv2.merge)
- java获取数据库存的日期和时间
- 计算机网络 谢希仁5版 4-30