开启MySQL SQL执行日志需配置通用查询日志或慢查询日志。1. 通用日志记录所有SQL,通过SET GLOBAL general_log = ON启用,可输出至文件或表;2. 慢查询日志用于捕获执行时间超过阈值的SQL,通过SET GLOBAL slow_query_log = ON和long_query_time设置;3. 持久化配置需在my.cnf中添加相应参数并重启服务。生产环境建议慎用通用日志,避免性能影响和磁盘占用。

在 MySQL 中查看 SQL 执行日志,主要依赖于开启通用查询日志(General Query Log)或使用慢查询日志(Slow Query Log)来捕获执行的 SQL 语句。以下是具体操作方法。
通用查询日志会记录所有发送到 MySQL 服务器的 SQL 语句,适合用于调试和审计。
1. 查看当前是否开启:SHOW VARIABLES LIKE 'general_log%';general_log 值为 OFF,则未开启。
2. 开启通用日志(临时生效):SET GLOBAL general_log = ON;general_log_file 或 log_output 决定。
3. 设置日志输出方式:SET GLOBAL log_output = 'FILE';SET GLOBAL general_log_file = '/var/log/mysql/general.log';
- 输出到数据库表(mysql.general_log):SET GLOBAL log_output = 'TABLE';4. 查看日志内容:SELECT * FROM mysql.general_log ORDER BY event_time DESC LIMIT 100;如果你只关心执行时间较长的 SQL,建议使用慢查询日志,性能影响更小。
1. 开启慢查询日志:SET GLOBAL slow_query_log = ON;2. 设置慢查询阈值(单位:秒):SET GLOBAL long_query_time = 1;3. 指定慢日志文件路径:SET GLOBAL slow_query_log_file = '/var/log/mysql/slow.log';4. 查看慢查询日志内容:tail -f /var/log/mysql/slow.logmysqldumpslow /var/log/mysql/slow.log上述 SET 命令仅在当前运行时有效。要永久生效,需修改 MySQL 配置文件(如 my.cnf 或 my.ini)。
在 [mysqld] 段添加:[mysqld] # 开启通用日志 general_log = ON general_log_file = /var/log/mysql/general.log log_output = FILE <h1>开启慢查询日志</h1><p>slow_query_log = ON slow_query_log_file = /var/log/mysql/slow.log long_query_time = 1</p>
基本上就这些。根据实际需求选择开启通用日志或慢查询日志,注意通用日志对性能有一定影响,生产环境慎用。日志文件需要定期清理,避免占用过多磁盘空间。
以上就是如何在mysql中查看SQL执行日志的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号