问题:
电脑的系统坏了,得重新安装系统。此时的MySQL 也无法使用了。只能将MySQL 的数据拿出来。
但是把数据文件夹覆盖新系统上的MySQL 数据文件夹,启动之后居然报错!!!
解决办法:
发现数据目录下有对应数据库名称的文件夹,文件夹下有很多表名.ibd 的文件,这些文件其实就是数据,我们可以利用它们来恢复
恢复步骤:
1.在新库里面创建结构相同的数据库 和表
这个可以根据备份数据或本地数据库来弄,只需要表结构
2、丢弃表空间,使用下面的语句
ALTERTABLE table_nameDISCARDTABLESPACE;(table_name 是表名,需要对每张表执行一次该命令,可以先在notepad++ 上把每条命令编辑好。然后再一次执行)
注意:执行完后发现新库数据文件夹里table_name.idb 已被删除
3、拷贝
把老数据文件夹下的table_name.idb 文件复制到新数据文件夹下
(table_name 是表名,需要对每张表执行一次该操作)
4、导入表空间,再执行下面的语句
ALTERTABLE table_nameIMPORTTABLESPACE;(table_name 是表名,需要对每张表执行一次该操作)
然后数据就完美的恢复了。