MySql資料庫備份的幾種方式

来源:https://www.cnblogs.com/yourblog/archive/2019/02/15/10381962.html
-Advertisement-
Play Games

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

  1. 關閉mysql服務。
  2. 將備份的文件或目錄覆蓋mysql的data目錄。
  3. 啟動mysql服務。
  4. 對於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}  #暫停或啟動二進位日誌。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一.連接字元串 在上二篇中,ASP.NET Core 應用程式連接字元串是寫死在ConfigureServices代碼中,下麵介紹通過配置來實現。連接字元串可以存儲在 appsettings.json、用戶機密存儲、其他配置源中。 下麵示例演示appsettings.json 中存儲的連接字元串,這 ...
  • 1.概述 由於在單台伺服器上搭建災備環境需要KVM和NFS的支持,下麵先列出KVM的搭建流程,再列出使用NFS實現單台伺服器災備的流程。 A.搭建KVM環境 1>.主機環境準備 Linux System:CentOS6.5 ISO:CentOS-6.5-x86_64-bin-DVD1.iso 2>. ...
  • 本文是按照lfree的博客(https://www.cnblogs.com/lfree/p/10368332.html)中的內容,進行學習、測試、總結的。有些知識點也是在閱讀這篇博文時,發現不瞭解這方面的知識,遂網上搜索相關資料總結了一下。 1:Linux 設備裡面有個比較特殊的文件:/dev/[t... ...
  • 1 命令行模式登錄MySQL 2 命令行下使用:status 3 使用系統函數:version() 4 mysql --version 5 包管理工具(根據不同系統 rh系列或bsd系列) ...
  • 問題原因: 今天線上環境,突然出現一個問題,追蹤原因是資料庫中的一條語句報錯,錯誤內容:lock wait timeout exceeded; try restarting transactio 執行update table set status = 1 where id = 10002;是可以的。 ...
  • 在oracle中,臨時表分為會話級別(session)和事務級別(transaction)兩種。 會話級的臨時表在整個會話期間都存在,直到會話結束;事務級別的臨時表數據在transaction結束後消失,即commit/rollback或結束會話時,會清除臨時表數據。 1、事務級臨時表 on com ...
  • ...
  • 正文 MySQL Online DDL這個新特性是在 MySQL5.6.7 開始支持的,更早期版本的MySQL進行DDL對於DBA來說是非常痛苦的。現在主流版本都集中在5.6與5.7,為了更好的理解Online DDL的工作原理與機制,本文就對Online DDL的實現方式進行總結。 本文使用的My ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...