程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 命令行模式下備份、還原 MySQL 數據庫的語句小結

命令行模式下備份、還原 MySQL 數據庫的語句小結

編輯:關於MYSQL數據庫
為了安全起見,需要經常對數據庫作備份,或者還原。對於 MySQL 而言,最方便的方法可能就是用 phpMyAdmin 的導出、導入功能了,但如果你的數據庫體積比較大,作為 Web 應用的 phpMyAdmin 可能會遭遇“超時”而操作失敗。所以,學會在命令行模式下備份、還原數據庫,還是很有必要的。

1、備份數據庫
在 Linux 命令行模式下備份 MySQL 數據庫,用的是 mysqldump 命令:

復制代碼 代碼如下:
mysqldump -u mysqluser -p test_db


對以上命令稍作解釋:

•-u 意味著你要指定一個 MySQL 用戶名來連接數據庫服務,如上面的 mysqluser 即為 MySQL用戶名。
•-p 則意味著你需要有一個有效的,與以上用戶名對應的密碼。
•最後一個參數則是需要備份的那個數據庫的名稱:test_db

如果直接執行以上命令,緊接著就會提示需要輸入 MySQL 密碼,數據密碼後,它會直接將備份出來的 SQL 腳本顯示在屏幕上,這當然不是我們想要的結果。我們需要把數據庫備份成一個文件,可用以下命令:
復制代碼 代碼如下:
mysqldump -u mysqluser -p test_db > test_db.sql

這樣,就會在當前目錄下備份出一個名為test_db.sql的文件。

當然,如果數據庫體積比較大,通常會對備份出來的文件進行壓縮,備份和壓縮可以在同一行命令內完成:
復制代碼 代碼如下:
mysqldump -u mysqluser -p test_db | gzip > test_db.sql.gz

壓縮的時候,最好再給文件名加上擴展名.gz,以便下次還原數據庫的時候心中有數。

2、還原數據庫
還原數據庫的命令也很簡單,如果你備份出來的文件是未壓縮的版本,則還原數據庫的命令如下:
復制代碼 代碼如下:
cat test_db.sql | mysql -u mysqluser -p test_db

用cat命令,把 SQL 腳本內容輸出給 MySQL 程序以便還原。可以看到,MySQL 後面的幾個參數,跟備份時候的一樣。

如果是已壓縮版本的備份文件,則需用以下命令才能還原:
復制代碼 代碼如下:
gunzip < test_db.sql.gz | mysql -u mysqluser -p test_db

類似地,用gunzip命令,解壓縮,然後把腳本內容輸出給 MySQL 程序以便還原。

2012-10-08 update:

如不考慮將 .sql 文件壓縮打包的話,也可以用下面兩條語句分別導出、導入。
復制代碼 代碼如下:
mysqldump -u root -p test_db > test_db.sql
mysql -u root -p test_db < test_db.sql


備份MySQL數據庫的命令
復制代碼 代碼如下:
mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql

備份MySQL數據庫為帶刪除表的格式
備份MySQL數據庫為帶刪除表的格式,能夠讓該備份覆蓋已有數據庫而不需要手動刪除原有數據庫。
復制代碼 代碼如下:
mysqldump -–add-drop-table -uusername -ppassword databasename > backupfile.sql


直接將MySQL數據庫壓縮備份
復制代碼 代碼如下:
mysqldump -hhostname -uusername -ppassword databasename | gzip > backupfile.sql.gz

備份MySQL數據庫某個(些)表
復制代碼 代碼如下:
mysqldump -hhostname -uusername -ppassword databasename specific_table1 specific_table2 > backupfile.sql

同時備份多個MySQL數據庫
復制代碼 代碼如下:
mysqldump -hhostname -uusername -ppassword –databases databasename1 databasename2 databasename3 > multibackupfile.sql

僅僅備份數據庫結構
復制代碼 代碼如下:
mysqldump –no-data –databases databasename1 databasename2 databasename3 > structurebackupfile.sql

備份服務器上所有數據庫
復制代碼 代碼如下:
mysqldump –all-databases > allbackupfile.sql

還原MySQL數據庫的命令
復制代碼 代碼如下:
mysql -hhostname -uusername -ppassword databasename < backupfile.sql

還原壓縮的MySQL數據庫
復制代碼 代碼如下:
gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename

將數據庫轉移到新服務器
復制代碼 代碼如下:
mysqldump -uusername -ppassword databasename | mysql –host=*.*.*.* -C databasename
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved