久久青草精品A片狠狠,日韩欧美视频一区二区,亚洲国码AV日韩,国产精品黄在

mysql命令恢復(fù)數(shù)據(jù)

2025-01-16 16:41:01 1570

歡迎來(lái)到藍(lán)隊(duì)云技術(shù)小課堂,每天分享一個(gè)技術(shù)小知識(shí)。


使用mysqldump命令將數(shù)據(jù)庫(kù)中的數(shù)據(jù)備份成一個(gè)文本文件。需要恢復(fù)時(shí),可以使用 mysql命令 來(lái)恢復(fù)備份的數(shù)據(jù)。

mysql命令可以執(zhí)行備份文件中的 CREATE語(yǔ)句 和 INSERT語(yǔ)句 。通過(guò)CREATE語(yǔ)句來(lái)創(chuàng)建數(shù)據(jù)庫(kù)和表。通過(guò)INSERT語(yǔ)句來(lái)插入備份的數(shù)據(jù)。

基本語(yǔ)法:

mysql –u root –p [dbname] < backup.sql

其中,dbname參數(shù)表示數(shù)據(jù)庫(kù)名稱。該參數(shù)是可選參數(shù),可以指定數(shù)據(jù)庫(kù)名,也可以不指定。指定數(shù)據(jù)庫(kù)名時(shí),表示還原該數(shù)據(jù)庫(kù)下的表。此時(shí)需要確保MySQL服務(wù)器中已經(jīng)創(chuàng)建了該名的數(shù)據(jù)庫(kù)。不指定數(shù)據(jù)庫(kù)名時(shí),表示還原文件中所有的數(shù)據(jù)庫(kù)。此時(shí)sql文件中包含有CREATE DATABASE語(yǔ)句,不需要MySQL服務(wù)器中已存在這些數(shù)據(jù)庫(kù)。

1. 單庫(kù)備份中恢復(fù)單庫(kù)

使用root用戶,將之前練習(xí)中備份的testdb.sql文件中的備份導(dǎo)入數(shù)據(jù)庫(kù)中,命令如下:

如果備份文件中包含了創(chuàng)建數(shù)據(jù)庫(kù)的語(yǔ)句,則恢復(fù)的時(shí)候不需要指定數(shù)據(jù)庫(kù)名稱,如下所示

#備份文件中包含了創(chuàng)建數(shù)據(jù)庫(kù)的語(yǔ)句
mysql -uroot -p < testdb.sql

否則需要指定數(shù)據(jù)庫(kù)名稱,如下所示

#備份文件中不包含了創(chuàng)建數(shù)據(jù)庫(kù)的語(yǔ)句
mysql -uroot -p testdb < testdb.sql

2. 全量備份恢復(fù)

如果我們現(xiàn)在有昨天的全量備份,現(xiàn)在想整個(gè)恢復(fù),則可以這樣操作:

mysql -u root -pxxxx < all.sql

執(zhí)行完后,MySQL數(shù)據(jù)庫(kù)中就已經(jīng)恢復(fù)了all.sql文件中的所有數(shù)據(jù)庫(kù)。

補(bǔ)充:

如果使用--all-databases參數(shù)備份了所有的數(shù)據(jù)庫(kù),那么恢復(fù)時(shí)不需要指定數(shù)據(jù)庫(kù)。對(duì)應(yīng)的sql文件包含有CREATE DATABASE語(yǔ)句,可通過(guò)該語(yǔ)句創(chuàng)建數(shù)據(jù)庫(kù)。創(chuàng)建數(shù)據(jù)庫(kù)后,可以執(zhí)行sql文件中的USE語(yǔ)句選擇數(shù)據(jù)庫(kù),再創(chuàng)建表并插入記錄。

3. 從全量備份中恢復(fù)單庫(kù)

可能有這樣的需求,比如說(shuō)我們只想恢復(fù)某一個(gè)庫(kù),但是我們有的是整個(gè)實(shí)例的備份,這個(gè)時(shí)候我們可以從全量備份中分離出單個(gè)庫(kù)的備份。

舉例:

sed -n '/^-- Current Database: `testdb`/,/^-- Current Database: `/p' all_database.sql > testdb.sql

#分離完成后我們?cè)賹?dǎo)入testdb.sql即可恢復(fù)單個(gè)庫(kù)

4. 從單庫(kù)備份中恢復(fù)單表

這個(gè)需求還是比較常見(jiàn)的。比如說(shuō)我們知道哪個(gè)表誤操作了,那么就可以用單表恢復(fù)的方式來(lái)恢復(fù)。

舉例:我們有testdb整庫(kù)的備份,但是由于class表誤操作,需要單獨(dú)恢復(fù)出這張表。

cat testdb.sql | sed -e '/./{H;$!d;}' -e 'x;/CREATE TABLE `class`/!d;q' > class_structure.sql

cat testdb.sql | grep --ignore-case 'insert into `class`' > class_data.sql
#用shell語(yǔ)法分離出創(chuàng)建表的語(yǔ)句及插入數(shù)據(jù)的語(yǔ)句后 再依次導(dǎo)出即可完成恢復(fù)


#進(jìn)入數(shù)據(jù)庫(kù)
use testdb;

mysql> source class_structure.sql;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> source class_data.sql;
Query OK, 1 row affected (0.01 sec)

藍(lán)隊(duì)云官網(wǎng)上擁有完善的技術(shù)支持庫(kù)可供參考,大家可自行查閱,更多技術(shù)問(wèn)題,可以直接咨詢。同時(shí),藍(lán)隊(duì)云整理了運(yùn)維必備的工具包免費(fèi)分享給大家使用,需要的朋友可以直接咨詢。


更多技術(shù)知識(shí),藍(lán)隊(duì)云期待與你一起探索。



提交成功!非常感謝您的反饋,我們會(huì)繼續(xù)努力做到更好!

這條文檔是否有幫助解決問(wèn)題?

非常抱歉未能幫助到您。為了給您提供更好的服務(wù),我們很需要您進(jìn)一步的反饋信息:

在文檔使用中是否遇到以下問(wèn)題: