濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySql數(shù)據(jù)庫備份的幾種方式

MySql數(shù)據(jù)庫備份的幾種方式

熱門標(biāo)簽:萊西市地圖標(biāo)注 銷售語音電話機(jī)器人 常州網(wǎng)絡(luò)外呼系統(tǒng)開發(fā) 400電話申請信用卡 在哪里申請400電話 外呼系統(tǒng)電銷受騙 走過哪個省地圖標(biāo)注 安徽ai電話電銷機(jī)器人有效果嗎 巫師三血與酒地圖標(biāo)注

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引擎的表。

  1. 關(guān)閉mysql服務(wù)。
  2. 將備份的文件或目錄覆蓋mysql的data目錄。
  3. 啟動mysql服務(wù)。
  4. 對于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工具實(shí)現(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不一樣的是該方法所有的選項(xiàng)不需要添加引號)

$> 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í)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL數(shù)據(jù)庫的實(shí)時備份知識點(diǎn)詳解
  • mysql備份的三種方式詳解
  • mysql 數(shù)據(jù)庫備份的多種實(shí)現(xiàn)方式總結(jié)
  • MySQL數(shù)據(jù)庫入門之備份數(shù)據(jù)庫操作詳解
  • MySQL學(xué)習(xí)之?dāng)?shù)據(jù)庫備份詳解

標(biāo)簽:陽江 黃石 煙臺 鞍山 赤峰 果洛 河北 來賓

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySql數(shù)據(jù)庫備份的幾種方式》,本文關(guān)鍵詞  MySql,數(shù)據(jù)庫,備份,的,幾種,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySql數(shù)據(jù)庫備份的幾種方式》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySql數(shù)據(jù)庫備份的幾種方式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    两当县| 蚌埠市| 遂溪县| 铜川市| 上饶县| 麻江县| 琼结县| 宽甸| 双牌县| 翁牛特旗| 湟源县| 浠水县| 德令哈市| 泰和县| 修文县| 原平市| 乳山市| 楚雄市| 湘西| 濉溪县| 鹰潭市| 聊城市| 宜春市| 上饶市| 望城县| 霍山县| 扎鲁特旗| 辛集市| 涞源县| 博罗县| 荥经县| 赤峰市| 长沙市| 城步| 吉安市| 临洮县| 广德县| 平顶山市| 旬邑县| 锡林浩特市| 崇左市|