时间:2021-05-24
背景
从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: 0mysql.general_log也不能改成innodb
mysql> alter table mysql.general_log engine=myisam;Query OK, 242956 rows affected (2.41 sec)Records: 242956 Duplicates: 0 Warnings: 0mysql> 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
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
由于mysql默认的引擎为innodb,phpmyadmin创建表时没有特别指定引擎,也就是使用系统默认的innodb.这个引擎的使用跟mysql/data/目
数据库开启慢查询日志修改配置文件在配置文件my.ini中加上下面两句话log-slow-queries=C:\xampp\mysql_slow_query.lo
慢查询日志相关参数MySQL慢查询的相关参数解释:slow_query_log:是否开启慢查询日志,1表示开启,0表示关闭。slow_query_log:是否开
编辑my.cnf或者my.ini文件,去除下面这几行代码的注释:复制代码代码如下:log_slow_queries=/var/log/mysql/mysql-s
外键在MySQL中,表有两种引擎,一种是InnoDB,另外一种是myisam。如果使用的是InnoDB引擎,是支持外键约束的。外键的存在使得ORM框架在处理表关