溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Mysql怎么通過ibd文件恢復(fù)數(shù)據(jù)

發(fā)布時間:2022-06-29 09:31:22 來源:億速云 閱讀:264 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了Mysql怎么通過ibd文件恢復(fù)數(shù)據(jù)的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Mysql怎么通過ibd文件恢復(fù)數(shù)據(jù)文章都會有所收獲,下面我們一起來看看吧。

恢復(fù)步驟

1、創(chuàng)建數(shù)據(jù)庫(隨意創(chuàng)建)

2、創(chuàng)建數(shù)據(jù)表(備注:表結(jié)構(gòu)要和要恢復(fù)的表結(jié)構(gòu)一致,row_format要和ibd文件的row_format一致,否則,會提示兩者不一致。 當(dāng)前row_format=dynamic)

3、表的屬性查看

我們使用:show table status like ‘matlab’\G,查看表的屬性

備注:創(chuàng)建表時候的row_format和表屬性的不一致,基于innodb是,要把row_format設(shè)置成dynamic時,需要修改mysql的全局配置,直接在myql命令中修改:set global innodb_file_format=Barracuda;

4、表錯誤信息查看 show warnings

5、說明

我們在恢復(fù)表的時候,要保證row_format和ibd文件的一致,如果ibd文件是compact的話,需要建表的時候,設(shè)置成row_format=compact,在恢復(fù)的時候,自行解決,從第6步開始,重點(diǎn)說明如何去恢復(fù)。

6、恢復(fù)第一步:移除表空間

 **alter table matlab DISCARD TABLESPACE;**

7、恢復(fù)第二步:將備份的ibd文件,放到mysql->data->創(chuàng)建的數(shù)據(jù)庫名稱->,將ibd拷貝到此目錄下,如下圖所示
具體路徑查看

-- 使用sql查詢數(shù)據(jù)目錄
**show global variables like '%datadir%';**

8、恢復(fù)第三步:重新導(dǎo)入表空間

 **alter table matlab IMPORT TABLESPACE;**

9、當(dāng)執(zhí)行到上一步完成后,我們發(fā)現(xiàn)數(shù)據(jù)庫中的數(shù)據(jù)已經(jīng)完全恢復(fù)過來了

10、數(shù)據(jù)表的結(jié)構(gòu)一定要和恢復(fù)前的數(shù)據(jù)表結(jié)構(gòu)一致,否則恢復(fù)失敗,導(dǎo)致mysql進(jìn)程重啟,詳細(xì)情況需要查看mysql的error日志進(jìn)行分析,另外,mysql的CE工具提供了便捷的mysql參數(shù)配置修改功能

補(bǔ)充:Innodb與MyISAM存儲文件的區(qū)別

Innodb存儲文件分為:.frm,.idb
    .frm:存儲表定義
    .ibd:存儲數(shù)據(jù)和索引
MyISAM存儲文件分為:.frm,.myd,.myi
    .frm:存儲表定義
    .myd:存儲數(shù)據(jù)
    .myi:存儲索引

關(guān)于“Mysql怎么通過ibd文件恢復(fù)數(shù)據(jù)”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“Mysql怎么通過ibd文件恢復(fù)數(shù)據(jù)”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI