很多MySQL初學(xué)者都會遇到這樣的問題:在使用MySQL刪除數(shù)據(jù)庫的時候不小心把整個數(shù)據(jù)庫都刪除了,導(dǎo)致數(shù)據(jù)丟失。這時,恢復(fù)備份是一個比較好的解決辦法,但如果備份丟失或者備份不完全,那怎么辦呢?
當我們刪除一個數(shù)據(jù)庫的時候,實際上是把對應(yīng)的數(shù)據(jù)庫目錄從磁盤中刪除了。所以,如果我們的操作系統(tǒng)支持文件恢復(fù),那么可以通過文件恢復(fù)的方式來恢復(fù)被刪除的數(shù)據(jù)庫。
注意事項:
1. 如果MySQL還處于運行狀態(tài),那么在恢復(fù)數(shù)據(jù)庫之前,需要停止MySQL服務(wù)。
2. 盡量在恢復(fù)數(shù)據(jù)庫之前,保證操作系統(tǒng)的寫入操作最小化,以免覆蓋之前的數(shù)據(jù)。
3. 有時候,恢復(fù)出來的數(shù)據(jù)庫是不完整的,需要手動修復(fù)或者從備份中恢復(fù)數(shù)據(jù)。
下面是具體的步驟:
Step 1: 確認數(shù)據(jù)庫的目錄
首先需要確認刪除的數(shù)據(jù)庫的目錄,即原來的數(shù)據(jù)存放路徑。在MySQL中,可以使用如下命令查詢數(shù)據(jù)庫的存放目錄(以Linux系統(tǒng)為例):
mysql> show global variables like 'datadir';
+---------------+--------------------------+
| Variable_name | Value |
+---------------+--------------------------+
| datadir | /var/lib/mysql/ |
+---------------+--------------------------+
1 row in set (0.00 sec)
從輸出結(jié)果可以看出,數(shù)據(jù)庫存放的路徑是/var/lib/mysql/。
Step 2: 恢復(fù)數(shù)據(jù)庫目錄
在確認了數(shù)據(jù)庫的存放路徑之后,可以使用操作系統(tǒng)的文件恢復(fù)工具來恢復(fù)目錄。
舉個例子,如果我們在Linux系統(tǒng)中誤刪除了一個名為mytest的數(shù)據(jù)庫,那么可以使用如下命令,恢復(fù)數(shù)據(jù)目錄:
cd /var/lib/mysql/
ls
rm -rf mytest/
testdisk # 打開 testdisk 文件恢復(fù)工具
(按照提示來恢復(fù)即可)
Step 3: 配置文件修復(fù)
如果上一步恢復(fù)的數(shù)據(jù)目錄不完整,那么需要手動修復(fù)或者從備份中恢復(fù)數(shù)據(jù)。修復(fù)完之后,還需要修改MySQL的配置文件,修改datadir的值。
在Linux系統(tǒng)中,MySQL的配置文件通常在/etc/my.cnf或者/etc/mysql/my.cnf中。修改datadir的值為恢復(fù)后的目錄即可:
[mysqld]
datadir = /var/lib/mysql/
socket = /var/lib/mysql/mysql.sock
[client]
socket = /var/lib/mysql/mysql.sock
Step 4: 啟動MySQL服務(wù)
在修復(fù)MySQL的配置文件之后,就可以重新啟動MySQL服務(wù)了。在以root用戶登錄Linux系統(tǒng)后,可以使用如下命令來啟動MySQL服務(wù):
systemctl start mysqld
到這里,數(shù)據(jù)庫的恢復(fù)就完成了。我們可以通過如下命令,查看恢復(fù)后的數(shù)據(jù)庫是否已經(jīng)恢復(fù)成功:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
| mytest |
+--------------------+
5 rows in set (0.00 sec)
恢復(fù)成功后,還需要檢查一下數(shù)據(jù)是否準確無誤。如果數(shù)據(jù)有誤,需要手動修復(fù)或者從備份中恢復(fù)數(shù)據(jù)。