MySQL中slow

57次阅读
没有评论

共计 1420 个字符,预计需要花费 4 分钟才能阅读完成。

自动写代码机器人,免费开通

丸趣 TV 小编给大家分享一下 MySQL 中 slow_log 表无法修改成 innodb 引擎怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

背景

从 mysql.slow_log 获取慢查询日志很慢,该表是 csv 表,没有索引。

想添加索引来加速访问,而 csv 引擎不能添加索引(csv 引擎存储是以逗号分割的文本来存储的),只能改存储引擎来添加索引了

mysql.slow_log 表能改成 myisam,不能改成 innodb

MySQL 中 slow_log 表无法修改成 innodb 引擎怎么办

mysql  set global slow_query_log=off;
Query OK, 0 rows affected (0.00 sec)
mysql  alter table mysql.slow_log engine=innodb;
ERROR 1579 (HY000): This storage engine cannot be used for log tables 
mysql  alter table mysql.slow_log engine=myisam;
Query OK, 33760 rows affected (0.37 sec)
Records: 33760 Duplicates: 0 Warnings: 0

mysql.general_log 也不能改成 innodb

mysql  alter table mysql.general_log engine=myisam;
Query OK, 242956 rows affected (2.41 sec)
Records: 242956 Duplicates: 0 Warnings: 0
mysql  alter table mysql.general_log engine=innodb;
ERROR 1579 (HY000): This storage engine cannot be used for log tables

官方文档

MySQL 中 slow_log 表无法修改成 innodb 引擎怎么办

官方文档说明,日志表只支持 csv 引擎和 myisam 引擎。

为什么不支持 innodb 引擎并未说明

基于什么来考虑不支持 innodb 表的了?

像朋友请教了下

估计是日志表 这种引擎会耗费大量的 redo, undo 资源吧

这是没有必要的。。。这些数据不重要。。

更改日志表存储引擎

SET @old_log_state = @@global.general_log;
SET GLOBAL general_log =  OFF 
ALTER TABLE mysql.general_log ENGINE = MyISAM;
SET GLOBAL general_log = @old_log_state;

归档日志表

USE mysql;
DROP TABLE IF EXISTS general_log2;
CREATE TABLE general_log2 LIKE general_log;
RENAME TABLE general_log TO general_log_backup, general_log2 TO general_log;

以上是“MySQL 中 slow_log 表无法修改成 innodb 引擎怎么办”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1420字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)