您好,登錄后才能下訂單哦!
Mysql5.7利用frm與ibd恢復(fù)數(shù)據(jù)
1、新建一個同名數(shù)據(jù)庫,并且在里面新建一張表同名的表,字段隨意。
---如果有原來表的表結(jié)構(gòu),那這步可以省略
將my.cnf配置文件增加innodb_force_recovery=6
2、把備份的.frm文件覆蓋新建表的.frm文件,修改文件屬主和權(quán)限,重啟數(shù)據(jù)庫,這個時候會在err文件提示你表結(jié)構(gòu)的字段數(shù)不一致
3、重復(fù)再新建一張表同名的表,字段數(shù)和提示的一樣多,字段名字類型隨意
4、把備份的.frm文件覆蓋新建表的.frm文件,修改文件屬主和權(quán)限,重啟數(shù)據(jù)庫;這樣表結(jié)構(gòu)就恢復(fù)出來了。
5、根據(jù)表結(jié)構(gòu),再重建新的表,指定表的ROW_FORMAT屬性,ROW_FORMAT=COMPACT;
CREATE TABLE ty (
id bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
valid int(11) DEFAULT '1' COMMENT '是否有效 1:有效 0:無效',
rel varchar(25) DEFAULT NULL,
PRIMARY KEY (id)
) DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT;
這樣,表結(jié)構(gòu)就算是恢復(fù)完了。
6、恢復(fù)數(shù)據(jù)
在指定的數(shù)據(jù)庫中執(zhí)行丟棄表空間命令
alter table ty discard tablespace;
7、拷貝原來的ibd文件,并覆蓋新建表ibd,并修改權(quán)限
chown mysql.mysql ty.ibd
8、導(dǎo)入表空間
alter table ty import tablespace;
這樣整個數(shù)據(jù)就恢復(fù)回來了。
---------End-By-TangYun-----2019.10.14--------------
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。