首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL 8-优化所有表+索引

MySQL 8-优化所有表+索引
EN

Database Administration用户
提问于 2020-11-26 21:18:28
回答 2查看 1.6K关注 0票数 -1

我在几个数据库(InnoDB 8)中有一堆表(MySQL 8),每天运行垃圾收集脚本,删除不再需要的陈旧记录。所有表都有索引。

优化所有表(比如每周一次)以提高性能是否有意义?如果是这样的话,是否有好的命令可供运行?

我试着做

代码语言:javascript
运行
复制
sudo mysqlcheck -o --all-databases

但是得到以下错误消息:

代码语言:javascript
运行
复制
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK
EN

回答 2

Database Administration用户

回答已采纳

发布于 2020-11-29 07:36:57

别费神。InnoDB主要是自己照顾自己。OPTIMIZE暂时挤出了一些浪费的空间,但是当插入/等发生时会产生新的浪费。OPTIMIZE的性能优势仅次于零。

票数 1
EN

Database Administration用户

发布于 2020-11-26 21:39:00

这些消息对于InnoDB来说是正常的。你可以继续这样做。

InnoDB存储引擎像这样执行OPTIMIZE TABLE mydb.mytable;

代码语言:javascript
运行
复制
ALTER TABLE mydb.mytable ENGINE=InnoDB;
ANALYZE TABLE mydb.mytable;

我多年来一直提到这一点:

我建议每天或每周做一次分析

代码语言:javascript
运行
复制
sudo mysqlcheck --analyze --all-databases

然后,每月或每季度进行一次优化。

票数 1
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/280406

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档