问题:
电脑的系统坏了,得重新安装系统。此时的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
是表名,需要对每张表执行一次该操作)
然后数据就完美的恢复了。