SQL的慢查询

分析MySQL语句查询性能的方法除了使用 EXPLAIN 输出执行计划,还可以让MySQL记录下查询超过指定时间的语句,我们将超过指定时间的SQL语句查询称为“慢查询”。



查看/设置“慢查询”的时间定义

1
2
3
4
5
6
7
mysql> show variables  like  "long%" ;
+ -----------------+----------+
| Variable_name   | Value    |
+ -----------------+----------+
| long_query_time | 0.000100 |
+ -----------------+----------+
1 row  in  set  (0.00 sec)
如上述语句输出,“慢查询”的时间定义为0.0001秒(方便测试,一般设置为1-10秒)。使用下面语句定义“慢查询”时间
1
2
mysql>  set  long_query_time=0.0001;
Query OK, 0  rows  affected (0.00 sec)

开启“慢查询”记录功能

1
2
3
4
5
6
7
8
9
mysql> show variables  like  "slow%" ;
+ ---------------------+------------------------------------+
| Variable_name       | Value                              |
+ ---------------------+------------------------------------+
| slow_launch_time    | 2                                  |
| slow_query_log      |  OFF                                 |
| slow_query_log_file | /opt/mysql/data/localhost-slow.log |
+ ---------------------+------------------------------------+
rows  in  set  (0.00 sec)
上述语句查看“慢查询”的配置信息,你可以自定义日志文件的存放,但必须将 slow_query_log 全局变量设置为“ON”状态,执行以下语句:
1
2
mysql>  set  global  slow_query_log= ON ;
Query OK, 0  rows  affected (0.01 sec)
结果:
1
2
3
4
5
6
7
8
9
mysql> show variables  like  "slow%" ;
+ ---------------------+------------------------------------+
| Variable_name       | Value                              |
+ ---------------------+------------------------------------+
| slow_launch_time    | 2                                  |
| slow_query_log      |  ON                                  |
| slow_query_log_file | /opt/mysql/data/localhost-slow.log |
+ ---------------------+------------------------------------+
rows  in  set  (0.00 sec)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值