萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> mysql數據庫備份和還原

mysql數據庫備份和還原

前 MySQL 支持的免費備份工具有:mysqldump、mysqlhotcopy,還可以用 SQL 語法進行備份:BACKUP TABLE 或者 SELECT INTO OUTFILE,又或者備份二進制日志(binlog),還可以是直接拷貝數據文件和相關的配置文件

數據庫備份:

打開cmd 執行以下語句:

 代碼如下 復制代碼

mysqldump -h localhost -u root -proot databasename >d:databasename.sql

數據庫還原:

打開cmd執行以下語句

 代碼如下 復制代碼

mysql  -uroot -proot databasename < d:databasename.sql

當數據庫備份和還原操作並不是在同一台數據庫服務器上,可能會出現兩台服務器的mysql軟件安裝的編碼問題

比如在還原數據庫時會遇到“Unknown command '''.” 這種錯誤提示

則可以使用

 代碼如下 復制代碼

mysql  -uroot -proot  --default-character-set=gb2312 databasename < d:databasename.sql


mysqlhotcopy

2.1 備份
mysqlhotcopy 是一個 PERL 程序,最初由Tim Bunce編寫。它使用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 來快速備份數據庫。它是備份數據庫或單個表的最快的途徑,但它只能運行在數據庫文件(包括數據表定義文件、數據文件、索引文件)所在的機器上。mysqlhotcopy 只能用於備份 MyISAM,並且只能運行在 類Unix 和 NetWare 系統上。

mysqlhotcopy 支持一次性拷貝多個數據庫,同時還支持正則表達。以下是幾個例子:

 代碼如下 復制代碼

root#/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=yejr -p=yejr db_name /tmp (把數據庫目錄 db_name 拷貝到 /tmp 下)

root#/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=yejr -p=yejr db_name_1 ... db_name_n /tmp
root#/usr/local/mysql/bin/mysqlhotcopy -h=localhost -u=yejr -p=yejr db_name./regex/ /tmp

更詳細的使用方法請查看手冊,或者調用下面的命令來查看 mysqlhotcopy 的幫助:

 代碼如下 復制代碼

perldoc /usr/local/mysql/bin/mysqlhotcopy

注意,想要使用 mysqlhotcopy,必須要有 SELECT、RELOAD(要執行 FLUSH TABLES) 權限,並且還必須要能夠有讀取 datadir/db_name 目錄的權限。


2.2 還原

mysqlhotcopy 備份出來的是整個數據庫目錄,使用時可以直接拷貝到 mysqld 指定的 datadir (在這裡是 /usr/local/mysql/data/)目錄下即可,同時要注意權限的問題,如下例:

 代碼如下 復制代碼 root#cp -rf db_name /usr/local/mysql/data/
root#chown -R nobody:nobody /usr/local/mysql/data/

(將 db_name 目錄的屬主改成 mysqld 運行用戶)

copyright © 萬盛學電腦網 all rights reserved