手机看片精品高清国产日韩,色先锋资源综合网,国产哺乳奶水91在线播放,乱伦小说亚洲色图欧洲电影

mysql命令恢復數據

2025-01-16 16:41:01 201

歡迎來到藍隊云技術小課堂,每天分享一個技術小知識。


使用mysqldump命令將數據庫中的數據備份成一個文本文件。需要恢復時,可以使用 mysql命令 來恢復備份的數據。

mysql命令可以執行備份文件中的 CREATE語句 和 INSERT語句 。通過CREATE語句來創建數據庫和表。通過INSERT語句來插入備份的數據。

基本語法:

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

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

1. 單庫備份中恢復單庫

使用root用戶,將之前練習中備份的testdb.sql文件中的備份導入數據庫中,命令如下:

如果備份文件中包含了創建數據庫的語句,則恢復的時候不需要指定數據庫名稱,如下所示

#備份文件中包含了創建數據庫的語句
mysql -uroot -p < testdb.sql

否則需要指定數據庫名稱,如下所示

#備份文件中不包含了創建數據庫的語句
mysql -uroot -p testdb < testdb.sql

2. 全量備份恢復

如果我們現在有昨天的全量備份,現在想整個恢復,則可以這樣操作:

mysql -u root -pxxxx < all.sql

執行完后,MySQL數據庫中就已經恢復了all.sql文件中的所有數據庫。

補充:

如果使用--all-databases參數備份了所有的數據庫,那么恢復時不需要指定數據庫。對應的sql文件包含有CREATE DATABASE語句,可通過該語句創建數據庫。創建數據庫后,可以執行sql文件中的USE語句選擇數據庫,再創建表并插入記錄。

3. 從全量備份中恢復單庫

可能有這樣的需求,比如說我們只想恢復某一個庫,但是我們有的是整個實例的備份,這個時候我們可以從全量備份中分離出單個庫的備份。

舉例:

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

#分離完成后我們再導入testdb.sql即可恢復單個庫

4. 從單庫備份中恢復單表

這個需求還是比較常見的。比如說我們知道哪個表誤操作了,那么就可以用單表恢復的方式來恢復。

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

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語法分離出創建表的語句及插入數據的語句后 再依次導出即可完成恢復


#進入數據庫
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)

藍隊云官網上擁有完善的技術支持庫可供參考,大家可自行查閱,更多技術問題,可以直接咨詢。同時,藍隊云整理了運維必備的工具包免費分享給大家使用,需要的朋友可以直接咨詢。


更多技術知識,藍隊云期待與你一起探索。



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

這條文檔是否有幫助解決問題?

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

在文檔使用中是否遇到以下問題: