MySQL通过数据文件恢复数据库

2022-06-23 13:38:43

问题:

电脑的系统坏了,得重新安装系统。此时的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 是表名,需要对每张表执行一次该操作)

然后数据就完美的恢复了。

  • 作者:x²+(y-√³x²)²=1
  • 原文链接:https://blog.csdn.net/qq_45083975/article/details/122946935
    更新时间:2022-06-23 13:38:43