Database Backup:
開啟cmd 執行以下語句:
| 代碼如下 |
複製代碼 |
mysqldump -h localhost -u root -proot databasename >d:databasename.sql |
資料庫還原:
開啟cmd執行以下語句
| 代碼如下 |
複製代碼 |
mysql -uroot -proot databasename < d:databasename.sql |
當Database Backup和還原作業並不是在同一台資料庫伺服器上,可能會出現兩台伺服器的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 運行使用者)