SQL优化之慢查询

/ SQL优化 / 3 条评论 / 691人围观

什么是慢查询

慢查询,顾名思义,就是查询慢的sql语句,是指mysql记录所有执行超过long_query_time参数设定的时间阈值的SQL语句的日志。该日志能为SQL语句的优化带来很好的帮助。默认情况下,慢查询日志是关闭的,要使用慢查询日志功能,首先要开启慢查询日志功能。

慢查询配置

慢查询基本配置

配置了慢查询后,它会记录符合条件的SQL,包括:

通过下面命令查看下上面的配置:

慢查询日志文件分析

设置完成后,通过 show VARIABLES like 'datadir'来查看数据文件存放的位置。日志文件中的内容格式如下:

# User@Host: [root] @ localhost [127.0.0.1]
# Query_time: 0.000997  
# Lock_time: 0.000000 
# Rows_sent: 5  
# Rows_examined: 5
SET timestamp=1539153057;
SELECT * FROM `t_users` LIMIT 0, 1000;

慢查询分析工具

Mysqldumpslow

linux系统在mysql的bin目录下执行

./mysqldumpslow -s r -t 5 /usr/local/mysql/data/70KG-224-slow.log

请输入图片描述 可以看出查询总时间均为0S,是因为语句查询时间太短,实际上是按时间倒序来排的。

参数说明:

mysqldumpslow -s r -t 10 slow-mysql.log
-s order (c,t,l,r,at,al,ar) 
         c:总次数
         t:总时间
         l:锁的时间
         r:总数据行
         at(每次执行sql耗费的时间),al(每次执行sql加锁用的时间),ar(每次获取数据行数所用时间)【例如:at = 总时间/总次数】其中a表示average平均
  -t  top   指定取前面几天作为结果输出

pt_query_digest

这个工具安装起来比较复杂,非专业sql人员感觉没必要玩~

  1. 很好,写的很清晰

    回复
  2. 基佬留下你的裤衩子

    回复