天天看点

高性能的MySQL(2)单条SQL性能

实际应用中,分析单条查询SQL性能,有3种方法:show status、show profile和慢查询日志。

一、使用SHOW PROFILE

1、默认是禁用的,在会话中开启

1

2

<code>#开启profile</code>

<code>set</code> <code>profiling=1;</code>

2、当一个查询到达服务器时,此工具会把分析信息记录到一张临时表,并且给查询赋予一个从1开始的整数标识符,可以通过show profiles查看。

<a href="http://blog.51cto.com/attachment/201310/141838957.png" target="_blank"></a>

3、上面只显示了时间上的精度,但是有些时候我们需要更多的信息那么,我们可以使用

show profile for query 1;来看具体信息

当然我们可以通过INFORMATION_SCHEMA中对应的表来输出我们想要的信息。比如

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

<code>#要查询的SQL</code>

<code>SET</code> <code>@query_id = 1;</code>

<code>SELECT</code>

<code>    </code><code>#执行步骤</code>

<code>    </code><code>STATE,</code>

<code>    </code><code>#每个步骤总时间</code>

<code>    </code><code>SUM</code><code>(DURATION) </code><code>AS</code> <code>Total_R,</code>

<code>    </code><code>#每个步骤占用总时间比例</code>

<code>    </code><code>ROUND(</code>

<code>        </code><code>100 * </code><code>SUM</code><code>(DURATION) /</code>

<code>            </code><code>(</code><code>SELECT</code> <code>SUM</code><code>(DURATION) </code><code>FROM</code> <code>INFORMATION_SCHEMA.PROFILING</code>

<code>            </code><code>WHERE</code> <code>QUERY_ID = @query_id),2</code>

<code>    </code><code>) </code><code>AS</code> <code>Pct_R,</code>

<code>    </code><code>#相同步骤执行次数</code>

<code>    </code><code>COUNT</code><code>(*) </code><code>AS</code> <code>Calls,</code>

<code>    </code><code>#相同步骤平均执行时间</code>

<code>    </code><code>SUM</code><code>(DURATION) / </code><code>COUNT</code><code>(*) </code><code>AS</code> <code>"R/Call"</code>

<code>FROM</code> <code>INFORMATION_SCHEMA.PROFILING</code>

<code>WHERE</code> <code>QUERY_ID = @query_id</code>

<code>GROUP</code> <code>BY</code> <code>STATE</code>

<code>ORDER</code> <code>BY</code> <code>Total_R </code><code>DESC</code><code>;</code>

就可以看到下面的格式

<a href="http://blog.51cto.com/attachment/201310/150847218.png" target="_blank"></a>

通过结果,可以清楚看到消耗时间最多的是“发送数据(Sending data)”,这里主要是因为我查询了一个有500W记录的表,并且id没有使用索引。

二、使用SHOW STATUS

show status 命令返回了一些计数器。既有服务器级别的全局计数器,也有基于某个连接的会话级别的计数器。不同的计数器可见范围不一样,全局的计数器也会出现在show status的结果中,容易被误认为是会话级别的。

show session status/show status 会话级别

show global status 全局级别

show status 结果只是计数器,无法给出消耗多少时间。

比如查看会话或者从服务器启动以来的增删改查的次数

<code>show status </code><code>like</code> <code>"com_insert"</code><code>;</code>

<code>show status </code><code>like</code> <code>"com_delete"</code><code>;</code>

<code>show status </code><code>like</code> <code>"com_update"</code><code>;</code>

<code>show status </code><code>like</code> <code>"com_select"</code><code>;</code>

下面清空一下,再来做一次原来的查询

<a href="http://blog.51cto.com/attachment/201310/155313370.png" target="_blank"></a>

这个数字说明这个查询,没有使用到索引,影响了500W条数据。

三、期待Performance Schema早日实现和普及吧!

本文转自shayang8851CTO博客,原文链接:http://blog.51cto.com/janephp/1307369,如需转载请自行联系原作者