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


当前回答

如果本地版主允许这样做,我想推广我很久以前写的一个PHP库- https://github.com/Simbiat/optimize-tables 这个库的重点是允许根据表的参数和统计数据“智能”执行OPTIMIZE, ANALYZE, CHECK和REPAIR命令。我已经在CRON https://simbiat.ru上运行它2年多了,它一直很顺利(当然,除了一些调整和小的修复)。

你为什么要用这样的东西?嗯,README提供了更多细节,但简而言之,只有当您确实可以从中受益时,它才能帮助您运行相关操作。至少,它可以节省你的资源。

其他回答

对于所有数据库:

mysqlcheck -Aos -uuser -p 

数据库优化:

mysqlcheck -os -uroot -p dbtest3

这个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

下面的示例php脚本可以帮助您优化数据库中的所有表

<?php

dbConnect();

$alltables = mysql_query("SHOW TABLES");

while ($table = mysql_fetch_assoc($alltables))
{
   foreach ($table as $db => $tablename)
   {
       mysql_query("OPTIMIZE TABLE '".$tablename."'")
       or die(mysql_error());

   }
}

?>

我的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