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


当前回答

这个bash脚本将接受根密码作为选项,并逐个优化它,并输出状态:

#!/bin/bash

if [ -z "$1" ] ; then
  echo
  echo "ERROR: root password Parameter missing."
  exit
fi
MYSQL_USER=root
MYSQL_PASS=$1
MYSQL_CONN="-u${MYSQL_USER} -p${MYSQL_PASS}"
TBLLIST=""
COMMA=""
SQL="SELECT CONCAT(table_schema,'.',table_name) FROM information_schema.tables WHERE"
SQL="${SQL} table_schema NOT IN ('information_schema','mysql','performance_schema')"
for DBTB in `mysql ${MYSQL_CONN} -ANe"${SQL}"`
do
    echo OPTIMIZE TABLE "${DBTB};"
    SQL="OPTIMIZE TABLE ${DBTB};"
    mysql ${MYSQL_CONN} -ANe"${SQL}"
done

其他回答

从命令行:

mysqlcheck -o <db_name> -u<username> -p

然后输入密码

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

一个数据库:

mysqlcheck -o <db_schema_name>

所有数据库:

mysqlcheck -o --all-databases

对于所有数据库:

mysqlcheck -Aos -uuser -p 

数据库优化:

mysqlcheck -os -uroot -p dbtest3

用一个简单的shell脚本完成所有数据库中所有表的修复:

#!/bin/bash
mysqlcheck --all-databases
mysqlcheck --all-databases -o
mysqlcheck --all-databases --auto-repair
mysqlcheck --all-databases --analyze

MySQL管理员(MySQL GUI工具的一部分)可以在数据库级别为你做这些。

只需选择您的模式并按下右下角的Maintenance按钮。

由于GUI工具已经达到了生命结束的状态,他们很难在mysql页面上找到。通过谷歌:http://dev.mysql.com/downloads/gui-tools/5.0.html找到他们

我不知道新的MySQL Workbench是否也能做到这一点。

您可以使用mysqlcheck命令行工具,它也应该能够做到这一点。