快速开启MySQL慢日志查询的方法

数据库 MySQL
MySQL中使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化起到非常大的帮助。

MySQL慢日志查询对于很多刚接触MySQL数据的新人来说比较陌生,下面就为您介绍MySQL慢日志查询的用法和好处,供您参考。

mysql有一个功能就是可以log下来运行的比较慢的sql语句,默认是没有这个log的

打开 my.ini ,找到 [mysql] 在其下面添加

long_query_time = 2
log-slow-queries = D:/mysql/logs/slow.log #设置把日志写在那里,可以为空,系统会给一个缺省的文件
#log-slow-queries = /var/youpath/slow.log linux下host_name-slow.log
log-queries-not-using-indexes

long_query_time 是指执行超过多长时间(单位是秒)的sql会被记录下来,这里设置的是2秒。
log-slow-queries 设置日志所在位置,可以为空,系统会给一个缺省的文件host_name-slow.log,生成的日志就在mysql的data目录下
log-queries-not-using-indexes 就是字面意思,记录下没有使用索引的query。

以下是mysqldumpslow常用参数说明,详细的可应用mysqldumpslow -help查询。

-s,是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序(从大到小),ac、at、al、ar表示相应的倒叙。
-t,是top n的意思,即为返回前面多少条数据。
-g,后边可以写一个正则匹配模式,大小写不敏感。

接下来就是用mysql自带的慢查询工具mysqldumpslow分析了(mysql的bin目录下
),我这里的日志文件名字是host-slow.log。

列出记录次数最多的10个sql语句

mysqldumpslow -s c -t 10 host-slow.log

列出返回记录集最多的10个sql语句

mysqldumpslow -s r -t 10 host-slow.log

按照时间返回前10条里面含有左连接的sql语句

mysqldumpslow -s t -t 10 -g "left join" host-slow.log

使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化起到非常大的帮助。
 

 

 

【编辑推荐】

MYSQL查询重复记录的方法

MySQL随机查询的实现方法

MySQL查询分页的优化

MySQL查询结果按某值排序

MySQL查询中的非空问题
 

责任编辑:段燃 来源: 互联网
相关推荐

2017-04-01 19:00:25

MySQL慢查询

2010-10-14 15:07:44

MySQL慢查询

2018-10-12 16:45:10

MySQL查询日志数据库

2017-09-18 15:20:02

MySQL慢查询日志配置

2010-11-25 11:07:28

MySQL慢查询

2022-05-17 08:24:58

查询日志MySQL

2011-06-28 08:32:40

MySQL慢查询日志

2018-08-02 16:10:50

MySQL数据库清理

2022-12-26 00:48:38

2021-05-14 11:05:38

MySQL慢日志数据库

2021-04-07 10:38:43

MySQL数据库命令

2022-03-16 14:45:18

MySQL慢查询数据库

2010-10-27 14:34:56

Oracle日志文件

2020-09-13 13:05:41

MySQL慢查询数据

2010-06-02 13:46:19

MySQL慢查询

2023-05-26 08:21:59

Lock_TimeMySQL

2019-09-18 08:06:08

Redis数据库命令

2022-05-11 09:16:55

Linux网络

2021-03-25 16:15:24

SQL工具慢查询

2022-06-30 08:01:53

mysqlmyisamcount
点赞
收藏

51CTO技术栈公众号