mysql查询正在执行的语句
Posted 满血复活的回来写代码
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql查询正在执行的语句相关的知识,希望对你有一定的参考价值。
排查问题时,需要查看正在执行的SQL,可以用如下两种方式进行查看。
1: 使用show processlist,但是有个弊端,就是只能查看正在执行的sql语句,对应历史记录,查看不到。好处是不用设置,不会保存。
1 -- use information_schema; 2 -- show processlist; 3 或者: 4 -- select * from information_schema.`PROCESSLIST` where info is not null;
2、开启日志模式。(可以记录)
1 -- 1、设置 2 -- SET GLOBAL log_output = ‘TABLE‘; SET GLOBAL general_log = ‘ON‘; 3 -- SET GLOBAL log_output = ‘TABLE‘; SET GLOBAL general_log = ‘OFF‘; 4 5 -- 2、查询 6 SELECT * from mysql.general_log ORDER BY event_time DESC 7 8 -- 3、清空表(delete对于这个表,不允许使用,只能用truncate) 9 -- truncate table mysql.general_log;
注意:truncate 删除该表不会产生碎片。收集完成之后,需要及时关闭日志模式
以上是关于mysql查询正在执行的语句的主要内容,如果未能解决你的问题,请参考以下文章