欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySql數據庫備份的幾種方式

 更新時間:2019年12月06日 15:06:16   作者:KillerTwo  
這篇文章主要介紹了MySql數據庫備份的幾種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

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

備份系統(tǒng)中所有數據庫

$> mysqldump -u root -h host -p --all-databases > backdb.sql

直接復制整個數據庫目錄(對于InnoDB存儲引擎不適用)備份

windowns: installpath/mysql/data

linux: /var/lib/mysql

在復制前需要先執(zhí)行如下命令:

MYSQL> LOCK TABLES;
# 在復制過程中允許客戶繼續(xù)查詢表,
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
# 執(zhí)行前需要先創(chuàng)建dbname數據庫,如果backup.sql是mysqldump創(chuàng)建的備份文件則執(zhí)行是不需要dbname。
MYSQL> source backup.sql;
# 執(zhí)行source命令前需要先選擇數據庫。

直接復制數據庫目錄還原

注: 該方式必須確保原數據庫和待還原的數據庫主版本號一致,并且只適用于MyISAM引擎的表。

  1. 關閉mysql服務。
  2. 將備份的文件或目錄覆蓋mysql的data目錄。
  3. 啟動mysql服務。
  4. 對于linux系統(tǒng),復制完文件后需要將文件的用戶和組更改為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工具實現(xiàn)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表導出到文本文件。執(zhí)行成功后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} #暫?;騿佣M制日志。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 解決MySQL報錯:The last packet sent successfully to the server was 0 milliseconds ago.

    解決MySQL報錯:The last packet sent successfu

    這篇文章主要介紹了解決MySQL報錯:The last packet sent successfully to the server was 0 milliseconds ago問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例

    Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例

    本文主要介紹了Mysql中使用count加條件統(tǒng)計的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • 刪除mysql數據表如何操作

    刪除mysql數據表如何操作

    在本篇文章里小編給大家分享了關于刪除mysql數據表簡單方法,需要的朋友們可以參考學習下。
    2020-06-06
  • mysql安全啟動腳本mysqld_safe詳細介紹

    mysql安全啟動腳本mysqld_safe詳細介紹

    這篇文章主要介紹了mysql安全啟動腳本mysqld_safe詳細介紹,mysqld_safe增加了一些安全特性,需要的朋友可以參考下
    2014-07-07
  • Mysql??DATEDIFF函數用法總結示例詳解

    Mysql??DATEDIFF函數用法總結示例詳解

    MySQL DATEDIFF()函數是MySQL中常見的日期函數之一,它主要用于計算兩個日期之間的差值,單位可以是天、周、月、季度和年,DATEDIFF函數用于返回兩個日期的天數,這篇文章主要介紹了Mysql??DATEDIFF函數,包括語法格式和示例代碼講解,需要的朋友可以參考下
    2023-03-03
  • MySQL中TEXT與BLOB字段類型的區(qū)別

    MySQL中TEXT與BLOB字段類型的區(qū)別

    這篇文章主要介紹了MySQL中TEXT與BLOB字段類型的區(qū)別,本文總結了6大區(qū)別,需要的朋友可以參考下
    2014-08-08
  • MySQL備份時排除指定數據庫的方法

    MySQL備份時排除指定數據庫的方法

    這篇文章主要介紹了MySQL備份時排除指定數據庫的方法的相關資料,需要的朋友可以參考下
    2016-03-03
  • mysql innodb的監(jiān)控(系統(tǒng)層,數據庫層)

    mysql innodb的監(jiān)控(系統(tǒng)層,數據庫層)

    這篇文章主要介紹了mysql innodb的監(jiān)控(系統(tǒng)層,數據庫層)的相關資料,需要的朋友可以參考下
    2017-04-04
  • mysql不包含模糊查詢問題

    mysql不包含模糊查詢問題

    這篇文章主要介紹了mysql不包含模糊查詢問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL最左匹配原則詳細分析

    MySQL最左匹配原則詳細分析

    首先回顧一下什么是最左匹配(也有稱之為最左前綴)?顧名思義:最左優(yōu)先,以最左邊的為起點任何連續(xù)的索引都能匹配上。同時遇到范圍查詢(>、<、between、like)就會停止匹配
    2022-12-12

最新評論