MySql數(shù)據(jù)庫備份的幾種方式
mysqldump工具備份
備份整個數(shù)據(jù)庫
$> mysqldump -u root -h host -p dbname > backdb.sql
備份數(shù)據(jù)庫中的某個表
$> mysqldump -u root -h host -p dbname tbname1, tbname2 > backdb.sql
備份多個數(shù)據(jù)庫
$> mysqldump -u root -h host -p --databases dbname1, dbname2 > backdb.sql
備份系統(tǒng)中所有數(shù)據(jù)庫
$> mysqldump -u root -h host -p --all-databases > backdb.sql
直接復(fù)制整個數(shù)據(jù)庫目錄(對于InnoDB存儲引擎不適用)備份
windowns: installpath/mysql/data
linux: /var/lib/mysql
在復(fù)制前需要先執(zhí)行如下命令:
MYSQL> LOCK TABLES; # 在復(fù)制過程中允許客戶繼續(xù)查詢表, MYSQL> FLUSH TABLES; # 將激活的索引頁寫入硬盤。
mysqlhotcopy工具備份
備份數(shù)據(jù)庫或表最快的途徑,只能運(yùn)行在數(shù)據(jù)庫目錄所在的機(jī)器上,并且只能備份MyISAM類型的表。
要使用該備份方法必須可以訪問備份的表文件。
$> mysqlhotcopy -u root -p dbname /path/to/new_directory; #將數(shù)據(jù)庫復(fù)制到new_directory目錄。
mysql命令導(dǎo)入sql文件還原
$> mysql -u root -p [dbname] < backup.sql # 執(zhí)行前需要先創(chuàng)建dbname數(shù)據(jù)庫,如果backup.sql是mysqldump創(chuàng)建的備份文件則執(zhí)行是不需要dbname。 MYSQL> source backup.sql; # 執(zhí)行source命令前需要先選擇數(shù)據(jù)庫。
直接復(fù)制數(shù)據(jù)庫目錄還原
注: 該方式必須確保原數(shù)據(jù)庫和待還原的數(shù)據(jù)庫主版本號一致,并且只適用于MyISAM引擎的表。
- 關(guān)閉mysql服務(wù)。
- 將備份的文件或目錄覆蓋mysql的data目錄。
- 啟動mysql服務(wù)。
- 對于linux系統(tǒng),復(fù)制完文件后需要將文件的用戶和組更改為mysql運(yùn)行的用戶和組。
mysqlhotcopy快速恢復(fù)
停止mysql服務(wù),將備份數(shù)據(jù)庫文件復(fù)制到存放數(shù)據(jù)的位置(mysql的data文件夾),重先啟動mysql服務(wù)即可(可能需要指定數(shù)據(jù)庫文件的所有者)。
$> cp -R /usr/backup/test /usr/local/mysql/data # 如果恢復(fù)的數(shù)據(jù)庫已經(jīng)存在,則使用DROP語句刪除已經(jīng)存在的數(shù)據(jù)庫之后,恢復(fù)才能成功,還需要保證數(shù)據(jù)庫版本兼容。
相同版本數(shù)據(jù)庫之間遷移
$> mysqldump -h www.abc.com -uroot -p password dbname | $> mysqldump -h www.bcd.com -uroot -p password # 將服務(wù)器www.abc.com的數(shù)據(jù)庫dbname遷移到服務(wù)器www.bcd.com的相同版本數(shù)據(jù)庫上。
不同版本的mysql數(shù)據(jù)庫之間的遷移
備份原數(shù)據(jù)庫。
卸載原數(shù)據(jù)庫。
安裝新數(shù)據(jù)庫。
在新數(shù)據(jù)庫中還原備份的數(shù)據(jù)庫數(shù)據(jù)。
數(shù)據(jù)庫用戶訪問信息需要備份mysql數(shù)據(jù)庫。
默認(rèn)字符集問題,MySQL4.x中使用latin1作為默認(rèn)字符集,mysql5.x使用utf8作為默認(rèn)字符集。如果有中文數(shù)據(jù)需要對默認(rèn)字符集進(jìn)行更改。
不同數(shù)據(jù)庫之間的遷移
MyODBC工具實現(xiàn)MySQL和SQL Server之間的遷移。
MySQL Migration Toolkit工具。
表的導(dǎo)出和導(dǎo)入
SELECT ...... INTO OUTFILE 導(dǎo)出文本文件,該方法只能導(dǎo)出到數(shù)據(jù)庫服務(wù)器上,并且導(dǎo)出文件不能已存在。
MYSQL> SELECT ...... INTO OUTFILE filename [OPTIONS] MYSQL> SELECT * FROM test.person INTO OUTFILE "C:\person0.txt"; # 將表person里的數(shù)據(jù)導(dǎo)入為文本文件person0.txt。
mysqldump文件導(dǎo)出文本文件(和INTO OUTFILE不一樣的是該方法所有的選項不需要添加引號)
$> mysqldump -T path -u root -p dbname [tables] [OPTIONS] # -T參數(shù)表明導(dǎo)出文本文件。path導(dǎo)出數(shù)據(jù)的目錄。 $> mysqldump -T C:\test person -u root -p # 將test表中的person表導(dǎo)出到文本文件。執(zhí)行成功后test目錄下會有兩個文件,person.sql和person.txt
mysql命令導(dǎo)出文本文件
MYSQL> mysql -u root -p --execute="SELECT * FROM person;" test > C:\person3.txt; # 將test數(shù)據(jù)庫中的person表數(shù)據(jù)導(dǎo)出到person3.txt文本文件中。--vartical參數(shù)可以將一行分為多行顯示。 MYSQL> mysql -u root -p --vartical --execute="SELECT * FROM person;" test > C:\person3.txt; # --html將表導(dǎo)出為html文件,--xml文件將表導(dǎo)出為xml文件
LOAD DATA INFILE導(dǎo)入文本文件
MYSQL> LOAD DATA INFILE 'filename.txt' INTO TABLE tablename [OPTIONS] [IGNORE number LINES]; # [IGNORE number LINES]表示忽略行數(shù) MYSQL> LOAD DATA INFILE 'C:\person0.txt' INTO TABLE test.person;
mysqlimport導(dǎo)入文本文件
$> mysqlimport -u root -p dbname filename.txt [OPSTONS] # 導(dǎo)入的表名有文件名決定,導(dǎo)入數(shù)據(jù)之前表必須存在 $> mysqlimport -uroot -p test C:\backup\person.txt # 將數(shù)據(jù)導(dǎo)入到test數(shù)據(jù)庫的person表中。
使用mysqlbinlog恢復(fù)數(shù)據(jù)
$> mysqlbinlog [option] filename | mysql -u user -p password # filename為二進(jìn)制日志文件, $> mysqlbinlog --stop-date="2013-03-30 15:27:47" D:\MySQL\log\binlog\binlog.000008 | mysql -u root -p password # 根據(jù)日志文件binlog.000008將數(shù)據(jù)恢復(fù)到2013-03-30 15:27:47以前的操作。
啟動二進(jìn)制日志
log-bin = path/filename #日志文件存儲目錄和文件名 expire_log_days = 10 #日志自動刪除時間 max_binlog_size = 100M # 日志文件最大大小
查看二進(jìn)制日志
MYSQL> SHOW VARIABLES LIKE 'log_%'; MYSQL> SHOW BINARY LOGS; $> mysqlbinlog filename # filename為二進(jìn)制日志文件名。
刪除二進(jìn)制日志
MYSQL> RESET MASTER; #刪除所有二進(jìn)制日志
MYSQL> PURGE {MASTER | BINARY} LOGS TO 'log_name'; #刪除文件編號小于log_name編號的文件
MYSQL> PURGE {MASTER | BINARY} LOGS BEFORE 'date'; #刪除指定日期以前的文件
暫時停止二進(jìn)制日志(不需要重啟mysql服務(wù))
MYSQL> SET sql_log_bin = {0|1} #暫?;騿佣M(jìn)制日志。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MySql中 is Null段判斷無效和IFNULL()失效的解決方案
這篇文章主要介紹了MySql中 is Null段判斷無效和IFNULL()失效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06
SQL行列轉(zhuǎn)置以及非常規(guī)的行列轉(zhuǎn)置示例代碼
轉(zhuǎn)置即旋轉(zhuǎn)數(shù)據(jù)表的橫縱方向,常用來改變數(shù)據(jù)布局,以便用新的角度觀察,下面這篇文章主要給大家介紹了關(guān)于SQL行列轉(zhuǎn)置以及非常規(guī)行列轉(zhuǎn)置的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08
MySql數(shù)據(jù)庫單表查詢與多表連接查詢效率對比
在遇到數(shù)據(jù)之間的聯(lián)系很復(fù)雜,建表就很糾結(jié),到底該怎么去處理這些復(fù)雜的數(shù)據(jù)呢,是單表查詢,然后在業(yè)務(wù)層去處理數(shù)據(jù)間的關(guān)系,還是直接通過多表連接查詢來處理數(shù)據(jù)關(guān)系呢2021-09-09
mysql 5.7.11 winx64.zip安裝配置方法圖文教程
這篇文章主要為大家分享了mysql5.7.11安裝配置方法圖文教程,具有一定的參考價值,感興趣的朋友可以參考一下2017-02-02
MySQL數(shù)據(jù)庫安全設(shè)置與注意事項小結(jié)
現(xiàn)在很多朋友使用mysql數(shù)據(jù)庫,為了安全考慮我們就需要考慮到mysql的安全問題,例如需要將mysql以普通用戶權(quán)限運(yùn)行,就算出問題了有了root也不能控制系統(tǒng)2013-08-08
在Linux系統(tǒng)的命令行中為MySQL創(chuàng)建用戶的方法
這篇文章主要介紹了在Linux系統(tǒng)的命令行中為MySQL創(chuàng)建用戶的方法,包括對所建用戶的權(quán)限管理,需要的朋友可以參考下2015-06-06
MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的步驟
因為一個項目交接需要需要將mysql物理備份文件還原至MySQL5.7,并且將mysql5.7升級到MySQL8.0,下面這篇文章主要給大家介紹了關(guān)于MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的相關(guān)資料,需要的朋友可以參考下2023-03-03

