查看: 16|回复: 0

[Centos] optimize table出错解决方法

[复制链接]

1

主题

0

回帖

0

积分

积极分子

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2009-5-16
发表于 2024-2-25 00:00:00 | 显示全部楼层 |阅读模式
一个某某库大概360W,为了提高查询效率,做点优化,使用optimize table table.name;出现Table does not support optimize, doing recreate + analyze instead 
果断谷歌,查到一段E文。。。 

Everytime you do optimize MySQL, by using mysqlcheck -A -o or using ./mysql_optimize from here. 
You may see the output 

Table does not support optimize, doing recreate + analyze instead. 

It is because the table that you are using is InnoDB. 

You can optimize the InnoDB tables by using this. 

复制代码
代码如下:

ALTER TABLE table.name ENGINE='InnoDB'; 

This will create a copy of the original table, and drop the original table, and replace to the original place. 

Although this is safe, but I suggest you do backup and test first before doing this. 

原来如此,大致意思是说innodb的数据库不支持optimize,可以用 
ALTER TABLE table.name ENGINE='InnoDB'; 
该方法会对旧表以复制的方式新建一个新表,然后删除旧表。虽然这个过程是安全的,但是在进行操作时还是先进行备份为好 

还有一种方式: 

You can make OPTIMIZE TABLE work on other storage engines by starting mysqld with the --skip-new or --safe-mode option. In this case, OPTIMIZE TABLE is just mapped toALTER TABLE. 

上面是说要求我们在启动的时候指定--skip-new或者--safe-mode选项来支持optimize功能
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部