MySQL有一个OPTIMIZE TABLE命令,可以用来回收MySQL安装中未使用的空间。是否有一种方法(内置命令或通用存储过程)可以为数据库和/或服务器安装中的每个表运行这种优化,还是必须自己编写脚本?


当前回答

如果你想分析、修复和优化MySQL服务器中所有数据库中的所有表,你可以从命令行一气呵成。不过,您将需要root才能做到这一点。

mysqlcheck -u root -p --auto-repair --optimize --all-databases

运行该命令后,系统将提示您输入MySQL根密码。在那之后,它将开始,你将看到结果,因为它正在发生。

示例输出:

yourdbname1.yourdbtable1       OK
yourdbname2.yourdbtable2       Table is already up to date
yourdbname3.yourdbtable3
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK

etc..
etc...

Repairing tables
yourdbname10.yourdbtable10
warning  : Number of rows changed from 121378 to 81562
status   : OK

如果您不知道根密码并且正在使用WHM,您可以通过转到: Home > SQL Services > MySQL Root密码

其他回答

如果你想分析、修复和优化MySQL服务器中所有数据库中的所有表,你可以从命令行一气呵成。不过,您将需要root才能做到这一点。

mysqlcheck -u root -p --auto-repair --optimize --all-databases

运行该命令后,系统将提示您输入MySQL根密码。在那之后,它将开始,你将看到结果,因为它正在发生。

示例输出:

yourdbname1.yourdbtable1       OK
yourdbname2.yourdbtable2       Table is already up to date
yourdbname3.yourdbtable3
note     : Table does not support optimize, doing recreate + analyze instead
status   : OK

etc..
etc...

Repairing tables
yourdbname10.yourdbtable10
warning  : Number of rows changed from 121378 to 81562
status   : OK

如果您不知道根密码并且正在使用WHM,您可以通过转到: Home > SQL Services > MySQL Root密码

对于所有数据库:

mysqlcheck -Aos -uuser -p 

数据库优化:

mysqlcheck -os -uroot -p dbtest3

我的1美分,添加和TABLE_TYPE='BASE TABLE',所以我们可以跳过'VIEW'类型。

for table in `mysql -sss -e "select concat(table_schema,'.',table_name) from information_schema.tables where table_schema not in ('mysql','information_schema','performance_schema') and TABLE_TYPE='BASE TABLE' order by data_free desc;"`
do
mysql -e "OPTIMIZE TABLE $table;"
done

您可以在命令行中使用mysqlcheck来完成此操作。

一个数据库:

mysqlcheck -o <db_schema_name>

所有数据库:

mysqlcheck -o --all-databases

如果你是直接访问数据库,那么你可以写以下查询:

OPTIMIZE TABLE table1,table2,table3,table4......;