mysql frm ibd导入数据库_通过.frm和.ibd恢复mysql数据

.frm文件:保存了每个表的元数据,包括表结构的定义等;

.ibd文件:InnoDB引擎开启了独立表空间(my.ini中配置innodb_file_per_table = 1)产生的存放该表的数据和索引的文件。

1、安装相同版本的mysql;

找回表结构

2、找回表结构(若有表结构,直接导入表即可)

建立同名的表(InnoDB),不知道列数的话随意一个字段即可(如果字段个数不一致会报错,去日志文件中查看有列数重复这些步骤)

关闭mysql服务

用需要恢复的.frm文件覆盖新生成的.frm文件。

修改my.ini配置innodb_force_recovery = 6进入恢复模式(只读)。

启动mysql服务。

desc tble_name或者show create table tbl_name获取创建表结构语句。(直接查看表设计字段会导致数据库异常)

复制建表sql,删除表(不能直接删.frm和.ibd会导致新建时报已存在,如果直接删除文件,需要将frm文件拷贝回来,再drop表),执行sql创建表结构。(这个步骤要把innodb_force_recovery = 6注解掉或者回复为0,不然提示只读)。

这里会出现启动后没有表结构,这是需要查看mysql的日志文件

找到日志文件位置:

show variables like '%error%'

6a4787560ad4d1c5fae71e7d68a256af.png

这里的.是相对于mysql的,windows可以根据快捷方式找到mysql位置然后再找.err错误文件

找到报错信息为

2018-12-18T08:52:30.314230Z 2 [Warning] InnoDB: Table bookkeeping/concategory contains 1 user defined columns in InnoDB, but 3 columns in MySQL.

意思是新建的有1列,但是复制过来的frm文件中含有3列。这时候知道列数,重做上述步骤。

eb6c4fb24092454c7aaabaccc4003583.png

恢复数据

删除新建的表空间

单个执行删除表空间语句

ALTER TABLE DISCARD TABLESPACE;

批量删除空间,执行以下语句。

SELECT CONCAT('ALTER TABLE', table_name, 'DISCARD TABLESPACE;')FROMinformation_schema.TABLESWHERE TABLE_SCHEMA = 'db_name';

获得每个表的删除表空间语句,直接全部选中复制(Navicat)

d61c4d8a774120a15fab5bb2763c6121.png

在前后加上外键约束检查关闭和开启执行

6272dc0eff197516ff653dea278393c2.png

2.将待恢复的.ibd文件copy到目标数据库文件夹下(这时候在navicat中看不到表名,不要慌!!!),并修改文件权限(chown u:g file),批量修改权限chown mysql:mysql /usr/mysql/data/db_name/*

导入表空间

单个执行导入表空间语句

ALTER TABLE IMPORT TABLESPACE;

批量导入表空间

SELECT CONCAT('ALTER TABLE', table_name, 'IMPORT TABLESPACE;')FROMinformation_schema.TABLESWHERE TABLE_SCHEMA = 'db_name';

这里和删除一样,不赘述,复制所选语句,加上关闭开启检查,执行

可能出现问题

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

2.mysql 1812错误:copy的ibd文件没有赋权,用chown u:g file

c0a0ba44903a33423e8037fb9d219bac.png

3.mysql 1451错误: Cannot delete or update a parent row: a foreign

在前后加上

SET foreign_key_checks = 0; --先设置外键约束检查关闭

SET foreign_key_checks = 1; --开启外键约束检查,以保持表结构完整性

总结

1.建立表结构(有备份直接用,跳过第一步的找回表结构)

2.删除新建的表空间

3.拷贝.ibd数据文件覆盖新建的文件

4.导入表空间

以下内容和技术无关(身体是革命的本钱,不可用命换钱):

今日烹饪经验

土豆烧肉烧时,肉要顺着纹理切(不然容易碎),烧时可以多放生抽(提鲜),但是老抽千万不能超过半铲子(不然会变成碳),图就不放了,影响大家胃口。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值