Java研究者

SQL调优的利器——profiling与explain

2016-11-30  本文已影响270人  罗亮leon

对于 sql 性能的判断,你是否还是通过百度,看看人家的博客,通过别人的回答 做出判断,或是凭自己的一点知识加上猜想呢?如果是,那么你将很被动,百度出来的经验我们无法判断是否正确,如果出了问题,可能就不知道怎么办了 。其实我们完全可以通过分析得到我们想要的答案。

分析需要工具,今天我就给大家介绍两个很厉害的命令,通过它们,你将不用再求百度。

一、 profiling命令:

show profiles是5.0.37之后添加的,要想使用此功能,要确保版本在5.0.37之后。

我们直接上图:

profiling 状态

默认情况下,profiling 是关闭的,我们需要手工的打开

Paste_Image.png

打开之后我们就可以使用啦 ,试试看 show profiles

Paste_Image.png

啥也没有? 当然啦,我们还没有开始查询,我查询几条记录试试看。

Paste_Image.png

再show profiles:


sql历史记录

我们可以看到 我们查询的历史记录,执行的非常详细的时间。
如果我们想查看更详细的信息当然也是没有任何问题,我们继续往下,比如我想查看 第9条sql:

sql执行过程

在这里我们就可以看到这条sql执行的整个过程,我们不再需要猜测,直接可以看到权限验证、打开表,初始化,统计、排序,是否使用临时表等。
当前这条语句比较简单,我们可以看到主要花费的时间是在 sending data上。

二、explain命令

explain与profiling都是用于sql语句的分析,
explain是从整体上进行分析,包括扫描了多少行,是否使用索引,使用了什么索引,是否用到临时表,是否使用了文件排序。
profiling是分析一条sql从开始到结束的各个环节使用的时间。

我们使用explain来分析一条sql语句:

Paste_Image.png

参数说明:

这两个命令用起来其实也比较简单,对照每个参数的含义 就能对语句做出分析了,希望这篇文章能对大家有所帮助。

上一篇 下一篇

猜你喜欢

热点阅读