MySQL Binlog是MySQL數(shù)據(jù)庫(kù)中的一個(gè)日志文件,記錄了數(shù)據(jù)庫(kù)的所有操作,包括增刪改查等操作,如果在一個(gè)意外宕機(jī)或誤操作后,我們需要對(duì)一張表進(jìn)行恢復(fù),可以通過(guò)Binlog來(lái)恢復(fù)。
下面是一個(gè)簡(jiǎn)單的Binlog恢復(fù)表的步驟:
1. 進(jìn)入MySQL服務(wù)器,使用root賬戶登錄。 mysql -u root -p 2. 查找損壞表之前的binlog文件和位置。 mysql>show master status\G; *************************** 1. row *************************** File: mysql-bin.000001 Position: 294 Binlog_Do_DB: Binlog_Ignore_DB: 1 row in set (0.00 sec) 3. 創(chuàng)建一個(gè)新的數(shù)據(jù)庫(kù),并在其中創(chuàng)建一個(gè)新表。 mysql>create database test_db; mysql>use test_db; mysql>create table test_table (id int primary key, name varchar(100)); 4. 將損壞表之前的binlog文件中的命令復(fù)制到文本文件中,然后進(jìn)行修改,僅保留原損壞表的命令(如:更新、插入、刪除等)。 mysqlbinlog --start-position=95 mysql-bin.000001 >binlog.sql vim binlog.sql 5. 找到原損壞表的操作命令,執(zhí)行恢復(fù)。 mysql>\. binlog.sql;
經(jīng)過(guò)以上步驟,我們就可以通過(guò)Binlog恢復(fù)表了,但需要注意的是,如果我們的操作不當(dāng),可能會(huì)影響到其他數(shù)據(jù),請(qǐng)?jiān)诓僮髑爸?jǐn)慎考慮。