之前是一直没有听过explain这个关键字的, 最近因为项目中总是会有慢查询的一些操作, 所以请教了旁边的同事帮忙排查下原因, 看到同事用explain来分析一些sql语句, 感觉好像发现了新大陆一样。

于是自己也来学习下并总结自己学到的一些知识,如有问题欢迎拍砖。

首先来做个测试, 我这里有一张表: t_jiakao_keyword, 数据量在60W左右。
1, select * from t_jiakao_keyword

然后使用explain进行各种查询:

通过主键id去查询,其中有几个关键的指标需要关注:
首先看下 type 这列的结果,如果有类型是 ALL 时,表示预计会进行全表扫描(full table scan)。通常全表扫描的代价是比较大的,建议创建适当的索引,通过索引检索避免全表扫描。此外,全索引扫描(full index scan)的代价有时候是比全表扫描还要高的,除非是基于InnoDB表的主键索引扫描。

再来看下 Extra 列的结果,如果有出现 Using temporary 或者 Using filesort 则要多加关注:
Using temporary,表示需要创建临时表以满足需求,通常是因为GROUP BY的列没有索引,或者GROUP BY和ORDER BY的列不一样,也需要创建临时表,建议添加适当的索引。

Using filesort,表示无法利用索引完成排序,也有可能是因为多表连接时,排序字段不是驱动表中的字段,因此也没办法利用索引完成排序,建议添加适当的索引。

Using where,通常是因为全表扫描或全索引扫描时(type 列显示为 ALL 或 index),又加上了WHERE条件,建议添加适当的索引。
暂时想到上面几个,如果有遗漏,以后再补充。

其他状态例如:Using index、Using index condition、Using index for group-by 则都还好,不用紧张。

最后放出所有字段的一些说明及含义。sql查询最重要的是合理使用索引, 关键点还是在索引!


最新文章

  1. javascript函数小练习
  2. Jquery操作select,左右移动,双击移动 取到所有option的值
  3. android杂记
  4. Servlet 工作原理解析
  5. ctypes 操作 python 与 c++ dll 互传结构体指针
  6. SQL2008根据日志恢复
  7. 从日常开发说起,浅谈HTTP协议是做什么的。
  8. XUtils解析
  9. LSTM/RNN的应用Case
  10. SGU 104
  11. Nginx学习——http配置项解析编程
  12. C#Windows Form简易计算器实现(上)
  13. python模块之random
  14. 英特尔DRM内核驱动程序默认启用PSR2省电功能
  15. cpp 区块链模拟示例(六) 交易
  16. Flink - Scheduler
  17. SpringMVC 请求响应流程
  18. [ SHELL编程 ] 编程常用的ORACLE相关命令
  19. C#实现无标题栏窗体点击任务栏图标正常最小化或还原的解决方法
  20. Mozilla新特性只支持https网站,再次推动SSL证书普及

热门文章

  1. DB2日常维护——REORG TABLE命令优化数据库性能(转)
  2. echarts legend 重叠 (转载)
  3. java程序员理解js中的闭包
  4. the c programing language 学习过程4
  5. uva 1583
  6. UVA - 10118 Free Candies 记忆化搜索经典
  7. 0_OpenCV3.4.0+Visual Studio2017 + win10环境配置
  8. 多文件工程的编译-Makefile的简便写法
  9. dm642的中断定时器
  10. FusionCharts 2D帕累托图