mysql frm,ibd文件恢复数据

1,找回表结构

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

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

1.1,建立同名称表名 innoDB

1.2,关闭mysql服务

1.3,找到数据库data地址,用frm文件复制覆盖

1.4,找到mysql配置文件,修改配置 innodb_force_recovery = 6 恢复模式

1.5,启动mysql服务

1.6,获取创建表结构语句

show create table 表名

2,恢复数据

2.1,表结构恢复后,执行表的空间删除

ALTER TABLE 数据表名 DISCARD TABLESPACE;

ps:所有空间删除语句

SELECT CONCAT('ALTER TABLE ', table_name, ' DISCARD TABLESPACE;')
FROM information_schema.TABLES
WHERE TABLE_SCHEMA = '库名称'

2.2,将ibd文件复制覆盖到mysql数据文件夹下,将ibd文件进行授权

2.3,导入表空间数据

ALTER TABLE 表名 IMPORT TABLESPACE;

ps:所有空间表导入

SELECT CONCAT('ALTER TABLE ', table_name, ' IMPORT TABLESPACE;')
FROM information_schema.TABLES
WHERE TABLE_SCHEMA = '库名称';

 

ps:

将发生1080错误的表 FOW_FORMAT修改为COMPACT

 

你可能感兴趣的:(mysql)