MySql資料庫備份方式

2021-10-04 11:46:44 字數 3999 閱讀 7425

備份整個資料庫

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
windowns: installpath/mysql/data

linux: /var/lib/mysql

在複製前需要先執行如下命令:

mysql> lock tables;

# 在複製過程中允許客戶繼續查詢表,

mysql> flush tables;

# 將啟用的索引頁寫入硬碟。

備份資料庫或表最快的途徑,只能執行在資料庫目錄所在的機器上,並且只能備份myisam型別的表。

要使用該備份方法必須可以訪問備份的表檔案。

mysqlhotcopy -u root -p dbname /path/to/new_directory;

#將資料庫複製到new_directory目錄。

mysql -u root -p [dbname] < backup.sql

# 執行前需要先建立dbname資料庫,如果backup.sql是mysqldump建立的備份檔案則執行是不需要dbname。

mysql> source backup.sql;

# 執行source命令前需要先選擇資料庫。

關閉mysql服務。

將備份的檔案或目錄覆蓋mysql的data目錄。

啟動mysql服務。

對於linux系統,複製完檔案後需要將檔案的使用者和組更改為mysql執行的使用者和組。

停止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資料庫。

預設字符集問題,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 [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 logs to 'log_name'; #刪除檔案編號小於log_name編號的檔案

mysql> purge logs before 'date'; #刪除指定日期以前的檔案

mysql> set sql_log_bin = 	#暫停或啟動二進位制日誌。

mysql資料庫備份方式

1 使用sqlyog視覺化工具備份,sqlyog工具可參考 右鍵需要備份的資料庫 備份 匯出 備份資料庫 2 總有一些人不習慣使用視覺化工具,可用命令列模式進行備份,開啟cmd命令列視窗 1 輸入命令 mysqldump u root p 資料庫名稱 檔案位置 資料庫名.sql 然後輸入資料庫roo...

MySql資料庫備份的幾種方式

備份整個資料庫 mysqldump u root h host p dbname backdb.sql備份資料庫中的某個表 mysqldump u root h host p dbname tbname1,tbname2 backdb.sql備份多個資料庫 mysqldump u root h ho...

MySql資料庫備份的幾種方式

mysqldump工具備份 備份整個資料庫 mysqldump u root h host p dbname backdb.sql備份資料庫中的某個表 mysqldump u root h host p dbname tbname1,tbname2 backdb.sql備份多個資料庫 mysqldu...