简介
有时,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;
在这个语句的输出中会出现一条消息,告诉你