數據庫備份:
打開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/(將 db_name 目錄的屬主改成 mysqld 運行用戶)