1、快速办法,运行sql语句show VARIABLES like \"大众%slow%\公众

2、直接去my.conf中查看。
这个文件在/etc/my.cnf

my.conf中的配置(放在[mysqld]下的下方加入)

php查询sql很慢如许能力更快的定位到你的慢查询sql语句 JavaScript

[mysqld]

log-slow-queries = /data/mysql/10-9-138-42-slow.log

long_query_time = 1 #单位是秒

log-queries-not-using-indexes

利用sql语句来修正:不能按照my.conf中的项来修正的。
修正通过\"大众show VARIABLES like \公众%slow%\公众 \"大众

语句列出来的变量,运行如下sql:

set global log_slow_queries = ON;

set global slow_query_log = ON;

set global long_query_time=0.1; #设置大于0.1s的sql语句记录下来

之后呢重启Mysql的数据库:利用 service 启动:service mysqld start

慢查询日志文件的信息格式:

select sleep(3); 这个便是关键信息,指明了当时实行的是这条语句

设置毫秒级别与mysql版本的关系

很多网上资料显示,5.21之前的版本,在my.conf中的long_query_time最小只能设置为1(也便是最小1秒)。
我自己歪打误撞,创造我通过其他办法可以实现。

\"大众long_query_time = 0.1\公众这种办法我没试,由于数据库做事器在跑。
须要重启。
以是没试。
我是通过全局变量设置实现慢日志查询记录的。

可以通过全局变量设置办法实现毫秒级别记录:

set global long_query_time = 0.01

我做事器上mysql版本为:5.5.53

我试过这种办法有效。

怎么测试自己的查询是否

会被记录下来呢?

运行语句

select sleep(3);

我故意设置3秒延迟,然后这条语句按照预期(由于之前设置超过0.1秒)会被记录到日志文件中去。