简介
有时,MySQL 表可能会损坏,这意味着发生了错误,其中保存的数据无法读取。尝试从损坏的表中读取通常会导致服务器崩溃。
一些常见的表损坏原因包括:
- MySQL 服务器在写入过程中停止。
- 外部程序修改了正在被服务器同时修改的表。
- 机器意外关闭。
- 计算机硬件故障。
- MySQL 代码中存在软件错误。
如果你怀疑你的表之一已经损坏,你应该在排除故障或尝试修复表之前备份数据目录。这将有助于最小化数据丢失的风险。
首先,停止 MySQL 服务:
sudo systemctl stop mysql
然后将所有数据复制到一个新的备份目录。在 Ubuntu 系统上,默认数据目录是 /var/lib/mysql/:
cp -r /var/lib/mysql /var/lib/mysql_bkp
备份完成后,你可以开始调查表是否确实损坏。如果表使用 MyISAM 存储引擎,你可以通过重新启动 MySQL 并从 MySQL 提示符下运行 CHECK TABLE 语句来检查它是否损坏:
sudo systemctl start mysql
CHECK TABLE table_name;
在这个语句的输出中会出现一条消息,告诉你它是否损坏。如果 MyISAM 表确实损坏,通常可以通过发出 REPAIR TABLE 语句来修复:

最低0.47元/天 解锁文章
9548

被折叠的 条评论
为什么被折叠?



