MySQL有一个OPTIMIZE TABLE命令,可以用来回收MySQL安装中未使用的空间。是否有一种方法(内置命令或通用存储过程)可以为数据库和/或服务器安装中的每个表运行这种优化,还是必须自己编写脚本?
当前回答
用一个简单的shell脚本完成所有数据库中所有表的修复:
#!/bin/bash
mysqlcheck --all-databases
mysqlcheck --all-databases -o
mysqlcheck --all-databases --auto-repair
mysqlcheck --all-databases --analyze
其他回答
这个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
用一个简单的shell脚本完成所有数据库中所有表的修复:
#!/bin/bash
mysqlcheck --all-databases
mysqlcheck --all-databases -o
mysqlcheck --all-databases --auto-repair
mysqlcheck --all-databases --analyze
从命令行:
mysqlcheck -o <db_name> -u<username> -p
然后输入密码
MySQL管理员(MySQL GUI工具的一部分)可以在数据库级别为你做这些。
只需选择您的模式并按下右下角的Maintenance按钮。
由于GUI工具已经达到了生命结束的状态,他们很难在mysql页面上找到。通过谷歌:http://dev.mysql.com/downloads/gui-tools/5.0.html找到他们
我不知道新的MySQL Workbench是否也能做到这一点。
您可以使用mysqlcheck命令行工具,它也应该能够做到这一点。
如果本地版主允许这样做,我想推广我很久以前写的一个PHP库- https://github.com/Simbiat/optimize-tables 这个库的重点是允许根据表的参数和统计数据“智能”执行OPTIMIZE, ANALYZE, CHECK和REPAIR命令。我已经在CRON https://simbiat.ru上运行它2年多了,它一直很顺利(当然,除了一些调整和小的修复)。
你为什么要用这样的东西?嗯,README提供了更多细节,但简而言之,只有当您确实可以从中受益时,它才能帮助您运行相关操作。至少,它可以节省你的资源。
推荐文章
- django test app error -在创建测试数据库时出现错误:创建数据库的权限被拒绝
- MySql: Tinyint (2) vs Tinyint(1) -有什么不同?
- 在Android SQLite中处理日期的最佳方法
- 如何在MySQL表中移动列?
- 在MySQL中选择最后一行
- 如何删除MySQL root密码
- 在SQL Server中查找重复的行
- 从DateTime中提取小时(SQL Server 2005)
- LEFT OUTER JOIN如何返回比左表中存在的记录更多的记录?
- 如何用SQL语句计算百分比
- Postgres唯一约束与索引
- SQL Server动态PIVOT查询?
- MySQL对重复键更新在一个查询中插入多行
- 向现有表添加主键
- mysql_connect():[2002]没有这样的文件或目录(试图通过unix:///tmp/mysql.sock连接)在