mysqldump工具備份 備份整個資料庫 $ mysqldump u root h host p dbname backdb.sql 備份資料庫中的某個表 $ mysqldump u root h host p dbname tbname1, tbname2 backdb.sql 備份多個資料庫 ...
mysqldump工具備份
備份整個資料庫
$> mysqldump -u root -h host -p dbname > backdb.sql
備份資料庫中的某個表
$> mysqldump -u root -h host -p dbname tbname1, tbname2 > backdb.sql
備份多個資料庫
$> mysqldump -u root -h host -p --databases dbname1, dbname2 > backdb.sql
備份系統中所有資料庫
$> mysqldump -u root -h host -p --all-databases > backdb.sql
直接複製整個資料庫目錄(對於InnoDB存儲引擎不適用)備份
windowns: installpath/mysql/data
linux: /var/lib/mysql
在複製前需要先執行如下命令:
MYSQL> LOCK TABLES;
# 在複製過程中允許客戶繼續查詢表,
MYSQL> FLUSH TABLES;
# 將激活的索引頁寫入硬碟。
mysqlhotcopy工具備份
備份資料庫或表最快的途徑,只能運行在資料庫目錄所在的機器上,並且只能備份MyISAM類型的表。
要使用該備份方法必須可以訪問備份的表文件。
$> mysqlhotcopy -u root -p dbname /path/to/new_directory;
#將資料庫複製到new_directory目錄。
mysql命令導入sql文件還原
$> mysql -u root -p [dbname] < backup.sql
# 執行前需要先創建dbname資料庫,如果backup.sql是mysqldump創建的備份文件則執行是不需要dbname。
MYSQL> source backup.sql;
# 執行source命令前需要先選擇資料庫。
直接複製資料庫目錄還原
註: 該方式必須確保原資料庫和待還原的資料庫主版本號一致,並且只適用於MyISAM引擎的表。
- 關閉mysql服務。
- 將備份的文件或目錄覆蓋mysql的data目錄。
- 啟動mysql服務。
- 對於linux系統,複製完文件後需要將文件的用戶和組更改為mysql運行的用戶和組。
mysqlhotcopy快速恢復
停止mysql服務,將備份資料庫文件複製到存放數據的位置(mysql的data文件夾),重先啟動mysql服務即可(可能需要指定資料庫文件的所有者)。
$> cp -R /usr/backup/test /usr/local/mysql/data
# 如果恢復的資料庫已經存在,則使用DROP語句刪除已經存在的資料庫之後,恢復才能成功,還需要保證資料庫版本相容。
相同版本資料庫之間遷移
$> mysqldump -h www.abc.com -uroot -p password dbname |
$> mysqldump -h www.bcd.com -uroot -p password
# 將伺服器www.abc.com的資料庫dbname遷移到伺服器www.bcd.com的相同版本資料庫上。
不同版本的mysql資料庫之間的遷移
備份原資料庫。
卸載原資料庫。
安裝新資料庫。
在新資料庫中還原備份的資料庫數據。
資料庫用戶訪問信息需要備份mysql資料庫。
預設字元集問題,MySQL4.x中使用latin1作為預設字元集,mysql5.x使用utf8作為預設字元集。如果有中文數據需要對預設字元集進行更改。
不同資料庫之間的遷移
MyODBC工具實現MySQL和SQL Server之間的遷移。
MySQL Migration Toolkit工具。
表的導出和導入
SELECT ...... INTO OUTFILE 導出文本文件,該方法只能導出到資料庫伺服器上,並且導出文件不能已存在。
MYSQL> SELECT ...... INTO OUTFILE filename [OPTIONS]
MYSQL> SELECT * FROM test.person INTO OUTFILE "C:\person0.txt";
# 將表person里的數據導入為文本文件person0.txt。
mysqldump文件導出文本文件(和INTO OUTFILE不一樣的是該方法所有的選項不需要添加引號)
$> mysqldump -T path -u root -p dbname [tables] [OPTIONS]
# -T參數表明導出文本文件。path導出數據的目錄。
$> mysqldump -T C:\test person -u root -p
# 將test表中的person表導出到文本文件。執行成功後test目錄下會有兩個文件,person.sql和person.txt
mysql命令導出文本文件
MYSQL> mysql -u root -p --execute="SELECT * FROM person;" test > C:\person3.txt;
# 將test資料庫中的person表數據導出到person3.txt文本文件中。--vartical參數可以將一行分為多行顯示。
MYSQL> mysql -u root -p --vartical --execute="SELECT * FROM person;" test > C:\person3.txt;
# --html將表導出為html文件,--xml文件將表導出為xml文件
LOAD DATA INFILE導入文本文件
MYSQL> LOAD DATA INFILE 'filename.txt' INTO TABLE tablename [OPTIONS] [IGNORE number LINES];
# [IGNORE number LINES]表示忽略行數
MYSQL> LOAD DATA INFILE 'C:\person0.txt' INTO TABLE test.person;
mysqlimport導入文本文件
$> mysqlimport -u root -p dbname filename.txt [OPSTONS]
# 導入的表名有文件名決定,導入數據之前表必須存在
$> mysqlimport -uroot -p test C:\backup\person.txt
# 將數據導入到test資料庫的person表中。
使用mysqlbinlog恢複數據
$> mysqlbinlog [option] filename | mysql -u user -p password
# filename為二進位日誌文件,
$> mysqlbinlog --stop-date="2013-03-30 15:27:47" D:\MySQL\log\binlog\binlog.000008 | mysql -u root -p password
# 根據日誌文件binlog.000008將數據恢復到2013-03-30 15:27:47以前的操作。
啟動二進位日誌
log-bin = path/filename #日誌文件存儲目錄和文件名
expire_log_days = 10 #日誌自動刪除時間
max_binlog_size = 100M # 日誌文件最大大小
查看二進位日誌
MYSQL> SHOW VARIABLES LIKE 'log_%';
MYSQL> SHOW BINARY LOGS;
$> mysqlbinlog filename
# filename為二進位日誌文件名。
刪除二進位日誌
MYSQL> RESET MASTER; #刪除所有二進位日誌
MYSQL> PURGE {MASTER | BINARY} LOGS TO 'log_name'; #刪除文件編號小於log_name編號的文件
MYSQL> PURGE {MASTER | BINARY} LOGS BEFORE 'date'; #刪除指定日期以前的文件
暫時停止二進位日誌(不需要重啟mysql服務)
MYSQL> SET sql_log_bin = {0|1} #暫停或啟動二進位日誌。