我在几个数据库(InnoDB 8)中有一堆表(MySQL 8),每天运行垃圾收集脚本,删除不再需要的陈旧记录。所有表都有索引。
优化所有表(比如每周一次)以提高性能是否有意义?如果是这样的话,是否有好的命令可供运行?
我试着做
sudo mysqlcheck -o --all-databases
但是得到以下错误消息:
note : Table does not support optimize, doing recreate + analyze instead
status : OK
发布于 2020-11-29 07:36:57
别费神。InnoDB主要是自己照顾自己。OPTIMIZE
暂时挤出了一些浪费的空间,但是当插入/等发生时会产生新的浪费。OPTIMIZE
的性能优势仅次于零。
发布于 2020-11-26 21:39:00
这些消息对于InnoDB来说是正常的。你可以继续这样做。
InnoDB存储引擎像这样执行OPTIMIZE TABLE mydb.mytable;
ALTER TABLE mydb.mytable ENGINE=InnoDB;
ANALYZE TABLE mydb.mytable;
我多年来一直提到这一点:
Sep 27, 2015
:如何在MySQL中对表进行碎片整理?Jun 24, 2015
:在会改变之后调用优化表的准则?Feb 27, 2013
:mysql中优化表与分析表的区别是什么?Aug 04, 2011
:优化InnoDB默认设置我建议每天或每周做一次分析
sudo mysqlcheck --analyze --all-databases
然后,每月或每季度进行一次优化。
https://dba.stackexchange.com/questions/280406
复制相似问题