小编给大家分享一下mysql怎样从ibd文件恢复数据,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

mysql从ibd文件恢复数据的方法:首先创建一张表,表结构与原表结构一致;然后删除新建的表空间;接着将待恢复的【.ibd】文件copy到目标数据库文件夹下,并修改文件权限;最后导入表空间。

mysql从ibd文件恢复数据的方法:

1、创建一张表,表结构与原表结构一致:

CREATETABLE<table_name>...;

2、删除新建的表空间:

ALTERTABLE<table_name>DISCARDTABLESPACE;

3、将待恢复的<table_name>.ibd文件copy到目标数据库文件夹下,并修改文件权限:

cp<table_name>.ibd/var/lib/mysql/<database_name>cd/var/lib/mysql/<database_name>chownmysql:mysql<table_name>.ibd

4、导入表空间:

ALTERTABLE<table_name>IMPORTTABLESPACE;

也可能出现如下问题:

1、mysql 1808错误:

ErrorCode:1808.Schemamismatch(TablehasROW_TYPE_DYNAMICrowformat,<table_name>.ibdfilehasROW_TYPE_COMPACTrowformat.)

这是由于mysql 5.6的文件恢复到mysql 5.7版本导致的错误,需要在建表语句后面添加ROW_FORMAT=COMPACT,如下所示:

createtabletest(idint,namevarchar(10))row_format=compact;

2、mysql 1812错误:

ErrorCode:1812.Tablespaceismissingfortable<table_name>

copy的ibd文件没有赋权,请按照第二步执行权限

以上是“mysql怎样从ibd文件恢复数据”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!