欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL slow_log表无法修改成innodb引擎详解

程序员文章站 2024-02-24 14:18:51
背景 从mysql.slow_log 获取慢查询日志很慢,该表是csv表,没有索引。 想添加索引来加速访问,而csv引擎不能添加索引(csv引擎存储是以逗号分割的文...

背景

从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;

参考

selecting general query log and slow query log output destinations

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。