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