MySQL數(shù)據(jù)恢復(fù)工具:ibd2sql離線解析.ibd文件轉(zhuǎn)換為SQL
ibd2sql工具可能是您的救命稻草。這是一款能將離線ibd文件轉(zhuǎn)換為SQL語句的神器,可以幫助恢復(fù)寶貴的數(shù)據(jù)。
ibd2sql 是一個使用純 Python 3 編寫的工具,用于離線解析 MySQL InnoDB 存儲引擎的 IBD 文件,并將其轉(zhuǎn)換為 SQL 語句。該工具無需任何第三方依賴包,使用 GPL-3.0 許可證發(fā)布。
ibd2sql優(yōu)點(diǎn)
- 方便: 提取表的 DDL(數(shù)據(jù)定義語言)。
- 實(shí)用: 支持替換庫名(–schema)和表名(–table),可以在 SQL 語句中輸出完整的字段(–complete)。
- 簡單: 純 Python 3 代碼編寫,無依賴包。
- 支持眾多數(shù)據(jù)類型: 支持所有 MySQL 數(shù)據(jù)類型。
- 支持復(fù)雜的表結(jié)構(gòu): 支持分區(qū)表、注釋、主鍵、外鍵、約束、自增、普通索引、前綴索引、主鍵前綴索引、唯一索引、復(fù)合索引、默認(rèn)值、符號、虛擬字段、INSTANT、無主鍵等情況的表。
- 數(shù)據(jù)誤刪恢復(fù): 可以輸出被標(biāo)記為已刪除的數(shù)據(jù)。
- 安全: 離線解析 IBD 文件,僅需讀取權(quán)限。
- IBD文件強(qiáng)制解析:IBD文件如果損壞,可以恢復(fù)部分?jǐn)?shù)據(jù)。
- 支持范圍廣: 支持 MySQL 5.6、5.7、8.0、8.4、9.0。
ibd2sql缺點(diǎn)
- 性能: 對于大型表,解析和生成 SQL 語句的過程可能較慢。
- 數(shù)據(jù)完整性: 如果 IBD 文件本身已經(jīng)嚴(yán)重?fù)p壞,恢復(fù)的數(shù)據(jù)可能不完整。
- 資源消耗: 生成的 SQL 文件可能較大,需要足夠的磁盤空間和內(nèi)存。
ibd2sql參數(shù)說明
--version, -v, -V: 顯示版本信息。 --ddl, -d: 打印 DDL。 --sql: 打印數(shù)據(jù)的 SQL 語句。 --delete: 僅打印被標(biāo)記為已刪除的數(shù)據(jù)。 --complete-insert: 使用完整的插入語句。 --force, -f: 在遇到錯誤頁面時(shí)強(qiáng)制解析文件。 --set: 用實(shí)際數(shù)據(jù)填充 set/enum 而不是字符串。 --multi-value: 如果數(shù)據(jù)屬于同一頁面,則使用單個 SQL 語句。 --replace: 使用 "REPLACE INTO" 替換 "INSERT INTO"(默認(rèn))。 --table TABLE_NAME: 替換表名(不包括 DDL)。 --schema SCHEMA_NAME: 替換庫名(不包括 DDL)。 --sdi-table SDI_TABLE: 從這個 IBD 文件(分區(qū)表)讀取 SDI 頁面。 --where-trx WHERE_TRX: 事務(wù)過濾范圍,默認(rèn) (0,281474976710656)。 --where-rollptr WHERE_ROLLPTR: 回滾指針過濾范圍,默認(rèn) (0,72057594037927936)。 --limit LIMIT: 限制行數(shù)。 --debug, -D: 調(diào)試模式(輸出非常大)。 --debug-file DEBUG_FILE: 調(diào)試輸出文件,默認(rèn)為 sys.stdout。 --page-min PAGE_MIN: 如果頁面編號小于此值,則終止。 --page-max PAGE_MAX: 如果頁面編號大于此值,則終止。 --page-start PAGE_START: 索引頁面起始編號。 --page-count PAGE_COUNT: 頁面計(jì)數(shù)編號。 --page-skip PAGE_SKIP: 解析索引頁面時(shí)跳過某些頁面。 --mysql5: 適用于 MySQL 5.7 標(biāo)志。
環(huán)境依賴python3
tar xvf Python-3.6.1.tgz cd Python-3.6.1 mkdir -p /usr/local/python3 ./configure --prefix=/usr/local/python3 make && make install ln -s /usr/local/python3/bin/python3 /usr/bin/python3
安裝ibd2sql
[root@idc opt]# wget https://github.com/ddcw/ibd2sql/archive/refs/heads/main.zip[root@idc opt]# unzip main.zip[root@idc opt]# cd ibd2sql-main
解析ibd文件
[root@idc ibd2sql-main]# cp /jesong/mysql/qaqdb/inner_announcement.ibd /opt/ibd2sql-main/ [root@idc-mongo55 ibd2sql-main]# python3 main.py ./inner_announcement.ibd --sql --ddl
使用示例
##僅打印被標(biāo)記為已刪除的數(shù)據(jù) python3 main.py /jesong/mysql/qaqdb/el_inner_announcement.ibd --sql --ddl --delete ##使用完整的插入語句 python3 main.py /jesong/mysql/qaqdb/el_inner_announcement.ibd --sql --ddl --delete --complete-insert ##在遇到錯誤頁面時(shí)強(qiáng)制解析文件 python3 main.py /jesong/mysql/qaqdb/el_inner_announcement.ibd --sql --ddl --force ##替換表名 python3 main.py /jesong/mysql/qaqdb/el_inner_announcement.ibd --sql --ddl --complete-insert --table xxbox ##數(shù)據(jù)屬于同一頁面,則使用單個 SQL 語句(合并insert) python3 main.py /jesong/mysql/qaqdb/el_inner_announcement.ibd --sql --ddl --complete-insert --table xxbox --multi-value
總結(jié)
ibd2sql 是一個強(qiáng)大的工具,適用于多種 MySQL 數(shù)據(jù)管理和恢復(fù)場景。它的無依賴包、廣泛支持的 MySQL 版本和靈活的輸出選項(xiàng)使其成為處理 IBD 文件的有力工具。然而,對于大型表和嚴(yán)重?fù)p壞的 IBD 文件,使用時(shí)需要注意性能和數(shù)據(jù)完整性問題??傮w來說,ibd2sql 是一個值得推薦的工具,特別適合數(shù)據(jù)恢復(fù)、遷移和審計(jì)等任務(wù)。
到此這篇關(guān)于MySQL數(shù)據(jù)恢復(fù)工具:ibd2sql離線解析.ibd文件轉(zhuǎn)換為SQL的文章就介紹到這了,更多相關(guān)MySQL數(shù)據(jù)恢復(fù)工具ibd2sql解析.ibd文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL定時(shí)備份數(shù)據(jù)庫操作示例
這篇文章主要介紹了MySQL定時(shí)備份數(shù)據(jù)庫操作,結(jié)合實(shí)例形式分析了MySQL定時(shí)備份數(shù)據(jù)庫相關(guān)命令、原理、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03mysql中數(shù)據(jù)統(tǒng)計(jì)的技巧備忘錄
mysql是常用數(shù)據(jù)庫,對于數(shù)字操作相關(guān)的東西相當(dāng)方便,這篇文章主要給大家介紹了關(guān)于mysql中數(shù)據(jù)統(tǒng)計(jì)技巧的相關(guān)資料,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-05-055招帶你輕松優(yōu)化MySQL count(*)查詢性能
最近在公司優(yōu)化了幾個慢查詢接口的性能,總結(jié)了一些心得體會拿出來跟大家一起分享一下,文中的示例代碼講解詳細(xì),希望對大家會有所幫助2022-11-11安裝MySQL phpMyAdmin cpolar實(shí)現(xiàn)遠(yuǎn)程訪問連接的操作步驟
這篇文章主要給大家介紹了安裝 MySQL phpMyAdmin cpolar實(shí)現(xiàn)遠(yuǎn)程訪問連接的流程步驟,文中有詳細(xì)的圖文介紹,具有一定的參考價(jià)值,需要的朋友可以參考下2023-08-08