MySQL slow_log表无法修改成innodb引擎详解
2019-11-07 18:12
2775 查看
背景
从mysql.slow_log 获取慢查询日志很慢,该表是csv表,没有索引。
想添加索引来加速访问,而csv引擎不能添加索引(csv引擎存储是以逗号分割的文本来存储的),只能改存储引擎来添加索引了
mysql.slow_log表能改成myisam,不能改成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"
官方文档
官方文档说明,日志表只支持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
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- MySQL slow_log表不能修改成innodb引擎
- 生产环境紧急修改表存储引擎:MyISAM 为 InnoDB步骤
- MySQL存储引擎中MyISAM和InnoDB区别详解
- mysql修改数据库的存储引擎(InnoDB)
- mysql innodb 表无法删除/修改数据 错误:1205
- 基于InnoDB存储引擎的mysql数据库表结构详解
- MySQL存储引擎中的MyISAM和InnoDB区别详解
- MySQL数据库锁机制之MyISAM引擎表锁和InnoDB行锁详解
- 修改MySql默认存储引擎为InnoDB,启动报错
- 为什么在MySQL数据库中无法创建外键?(MyISAM和InnoDB详解)
- innodb存储引擎之二进制日志文件ROW和STATEMENT格式以及重做日志文件分析与系统恢复详解(未完待续)
- 修改MySQL的数据库引擎为INNODB的方法
- innoDB 储存引擎 IO THread 后台线程 innodb_read_io_threads 和 innodb_write_io_threads 两个参数详解记录
- java jdbc 修改mysql数据库的引擎 InnoDB
- 生产环境紧急修改表存储引擎:MyISAM 为 InnoDB步骤
- mysql修改数据库的存储引擎(InnoDB)
- MySQL存储引擎中的MyISAM和InnoDB区别详解
- 解决Default storage engine (InnoDB) is not available导致mysql无法启动的修改办法
- MySQL存储引擎中的MyISAM和InnoDB区别详解