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

MySQL邏輯備份的實現(xiàn)步驟

 更新時間:2025年03月05日 11:36:22   作者:ZZDICT  
本文主要介紹了MySQL邏輯備份的實現(xiàn)步驟,包括使用mysqldump和mysqlpump工具進(jìn)行備份和恢復(fù),文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

MySQL 的邏輯備份指的是使用 SQL 語句備份數(shù)據(jù)庫的結(jié)構(gòu)和數(shù)據(jù),而不是直接備份數(shù)據(jù)庫文件。通常使用 mysqldump 工具進(jìn)行邏輯備份。

一.mysqldump

mysqldump是最常用的邏輯備份工具,能夠生成SQL腳本文件,這些文件可以用來重建數(shù)據(jù)庫結(jié)構(gòu)和數(shù)據(jù)。

基本命令:

mysqldump -u [用戶名] -p[密碼] [數(shù)據(jù)庫名] > [備份文件.sql]

參數(shù)選項:

  • -u, --user=[name]:指定 MySQL 用戶名。
  • -p, --password[=password]:指定 MySQL 密碼。如果不提供密碼,mysqldump 會提示輸入。
  • -h, --host=[hostname]:指定 MySQL 服務(wù)器主機(jī)名。
  • -P, --port=[port_num]:指定 MySQL 服務(wù)器端口號。
  • --protocol=[{TCP|SOCKET|PIPE|MEMORY}]:指定連接協(xié)議。
  • -r, --result-file=[file]:將輸出直接寫入文件,而不是通過標(biāo)準(zhǔn)輸出。
  • -t, --no-create-info:不寫入創(chuàng)建表的語句,只導(dǎo)出數(shù)據(jù)。
  • -d, --no-data:不寫入數(shù)據(jù),只導(dǎo)出數(shù)據(jù)庫結(jié)構(gòu)。
  • --add-drop-table:在每個創(chuàng)建表語句前增加 DROP TABLE IF EXISTS 語句。
  • --add-locks:在插入數(shù)據(jù)前后使用 LOCK TABLES 和 UNLOCK TABLES 語句。
  • --disable-keys:在插入數(shù)據(jù)前使用 ALTER TABLE ... DISABLE KEYS,插入數(shù)據(jù)后使用 ALTER TABLE ... ENABLE KEYS
  • -B, --databases:指定要備份的數(shù)據(jù)庫。如果使用該選項,所有跟在其后的數(shù)據(jù)庫名都將被備份。
  • -A, --all-databases:備份所有數(shù)據(jù)庫。
  • --tables:指定要備份的表,必須跟在數(shù)據(jù)庫名之后。
  • -n, --no-create-db:不寫入創(chuàng)建數(shù)據(jù)庫的語句。
  • -w, --where='condition':僅導(dǎo)出符合指定條件的行。
  • --single-transaction:在一個事務(wù)中導(dǎo)出所有數(shù)據(jù),適用于支持事務(wù)的表(如 InnoDB)。
  • --lock-tables:在導(dǎo)出前鎖定所有表,適用于不支持事務(wù)的表(如 MyISAM)。
  • --master-data[=#]:在導(dǎo)出中加入主服務(wù)器的二進(jìn)制日志位置和文件名,用于設(shè)置復(fù)制。
  • --flush-logs:在導(dǎo)出前刷新 MySQL 服務(wù)器的日志。
  • --routines:導(dǎo)出存儲過程和函數(shù)。
  • --triggers:導(dǎo)出觸發(fā)器。
  • --events:導(dǎo)出事件。
  • --hex-blob:以十六進(jìn)制格式導(dǎo)出二進(jìn)制列。
  • --set-gtid-purged=[OFF|ON|AUTO]:控制是否在備份中加入 GTID 信息,適用于 GTID 復(fù)制。

示例

備份整個數(shù)據(jù)庫 

mysqldump -u root -p mydatabase > mydatabase_backup.sql

備份多個數(shù)據(jù)庫 

mysqldump -u root -p --databases db1 db2 > multi_database_backup.sql

備份所有數(shù)據(jù)庫 

mysqldump -u root -p --all-databases > all_databases_backup.sql

僅備份數(shù)據(jù)庫結(jié)構(gòu)

mysqldump -u root -p --no-data mydatabase > mydatabase_structure_backup.sql

僅備份特定表

mysqldump -u root -p mydatabase table1 table2 > mydatabase_tables_backup.sql

添加選項以有效處理鎖表問題

mysqldump -u root -p --single-transaction --quick --lock-tables=false mydatabase > mydatabase_backup.sql

恢復(fù)數(shù)據(jù)

恢復(fù)數(shù)據(jù)庫

語法

mysql -u [用戶名] -p[密碼] [數(shù)據(jù)庫名] < [備份文件.sql]

示例

mysql -u root -p mydatabase < mydatabase_backup.sql

恢復(fù)庫中的表 

mysqldump -u root -p[密碼] [庫名] [表名] > staff_backup.sql

使用source恢復(fù) 

首先登錄到mysql中,在mysql中使用下述語法恢復(fù)

source 文件路徑;

例: 

source /path/to/employees_backup.sql;

注意事項

  • 權(quán)限管理:確保執(zhí)行 mysqldump 和恢復(fù)命令的用戶具有相應(yīng)的數(shù)據(jù)庫讀寫權(quán)限。
  • 定期備份:邏輯備份通常對數(shù)據(jù)一致性和完整性要求較高,建議定期進(jìn)行備份并驗證備份文件的有效性。
  • 存儲位置:將備份文件存儲在安全的位置,避免丟失或被不當(dāng)修改。

二. mysqlpump

mysqlpump是MySQL 5.7引入的備份工具,支持多線程,能夠更快地進(jìn)行備份。它是 mysqldump 的增強(qiáng)版本。

mysqlpump 特點

  • 并行處理mysqlpump 支持并發(fā)地備份多個表和多數(shù)據(jù)庫,極大地提高了備份速度。
  • 更豐富的功能選項:支持過濾特定數(shù)據(jù)庫、表和數(shù)據(jù)以及導(dǎo)出的同時進(jìn)行壓縮等。
  • 增強(qiáng)的靈活性:提供更多參數(shù)以定制化備份操作。

基本命令:

mysqlpump -u [用戶名] -p[密碼] [數(shù)據(jù)庫名] > [備份文件.sql]

常用選項:

  • --exclude-databases:排除特定數(shù)據(jù)庫
  • --include-databases:包含特定數(shù)據(jù)庫
  • --default-parallelism:設(shè)置并行度
  • --skip-definer:忽略DEFINER子句
  • --set-gtid-purged:用于GTID的備份

示例

備份單個數(shù)據(jù)庫

mysqlpump -u root -p mydatabase > mydatabase_backup.sql

備份多個數(shù)據(jù)庫 

mysqlpump -u root -p --databases db1 db2 > multi_database_backup.sql

備份所有數(shù)據(jù)庫

mysqlpump -u root -p --all-databases > all_databases_backup.sql

并發(fā)處理

mysqlpump -u root -p --default-parallelism=4 --databases db1 db2 > multi_database_backup.sql

使用 --default-parallelism 參數(shù)可以設(shè)定并發(fā)線程數(shù),加快備份速度。 

過濾表

mysqlpump -u root -p mydatabase --exclude-tables=table1,table2 > mydatabase_backup.sql

使用 --exclude-tables 可以排除特定的表 

僅備份表結(jié)構(gòu)

mysqlpump -u root -p mydatabase --skip-dump-data > mydatabase_structure_backup.sql

壓縮備份文件

mysqlpump -u root -p mydatabase | gzip > mydatabase_backup.sql.gz

備份數(shù)據(jù)目錄

mysqlpump --users --routines --databases db1 db2 > backup_with_users_routines.sql

使用 --users 備份用戶賬戶,使用 --routines 備份存儲函數(shù)和存儲過程。

恢復(fù)數(shù)據(jù)庫

解壓縮備份文件

gunzip < mydatabase_backup.sql.gz | mysql -u root -p mydatabase

恢復(fù)備份

mysql -u [用戶名] -p [數(shù)據(jù)庫名] < [備份文件.sql]

示例

mysql -u root -p mydatabase < mydatabase_backup.sql

注意事項

  • 權(quán)限管理:確保執(zhí)行 mysqlpump 和恢復(fù)命令的用戶具有必要的數(shù)據(jù)庫讀寫權(quán)限。
  • 并發(fā)性:合理設(shè)定并發(fā)線程數(shù),避免服務(wù)器負(fù)載過高。
  • 定期備份:建議定期備份并驗證備份文件的完整性。
  • 存儲位置:將備份文件存儲在安全和可靠的位置,避免丟失或不當(dāng)修改。

邏輯備份的優(yōu)缺點

優(yōu)點

  • 可讀性強(qiáng):備份文件是文本格式的SQL腳本,易于查看和編輯。
  • 跨平臺:備份文件可以在不同操作系統(tǒng)和不同版本的MySQL之間移植。
  • 備份靈活:可以選擇備份整個數(shù)據(jù)庫、特定的表或結(jié)構(gòu)。

缺點

  • 性能開銷大:備份和恢復(fù)過程中會產(chǎn)生較大的CPU和I/O開銷,特別是對于大數(shù)據(jù)量的數(shù)據(jù)庫。
  • 恢復(fù)速度慢:相對于物理備份,邏輯備份的恢復(fù)速度較慢。
  • 一致性問題:如果沒有正確使用事務(wù)一致性選項,可能會導(dǎo)致數(shù)據(jù)不一致。

只備份表數(shù)據(jù)擴(kuò)展

/var/lib/mysql-files 是 MySQL 默認(rèn)用于存儲導(dǎo)出的文件的目錄。這個目錄通常用于 SELECT INTO OUTFILE 等操作所生成的文件。

mysqldump -n

介紹

mysqldump 是一個用于備份 MySQL 數(shù)據(jù)庫的工具。-n 參數(shù)讓你只備份表中數(shù)據(jù),不包括表結(jié)構(gòu)。備份得到的文件是純 SQL 語句,可以用來恢復(fù)數(shù)據(jù)。

舉例

場景: 有一個名為 employees 的數(shù)據(jù)庫,其中包含 staff 表。備份 staff 表中的數(shù)據(jù),但不包括表結(jié)構(gòu)。

步驟:

進(jìn)入命令行。

執(zhí)行以下命令:

mysqldump -u root -p[密碼] --no-create-info employees staff > staff_data_only.sql

3.結(jié)果: 生成的 staff_data_only.sql 文件內(nèi)容:

INSERT INTO `staff` (`id`, `name`, `position`, `salary`) VALUES (1, 'Alice', 'Manager', 50000);
INSERT INTO `staff` (`id`, `name`, `position`, `salary`) VALUES (2, 'Bob', 'Engineer', 40000);
INSERT INTO `staff` (`id`, `name`, `position`, `salary`) VALUES (3, 'Charlie', 'Technician', 30000);

恢復(fù):

  • 在新環(huán)境中,確保已存在相同結(jié)構(gòu)的 staff 表。
  • 進(jìn)入 MySQL 客戶端,執(zhí)行:
source /path/to/staff_data_only.sql;

SELECT INTO OUTFILE

介紹

SELECT INTO OUTFILE 是一條SQL語句,用于將查詢結(jié)果導(dǎo)出到文件中。文件格式可以根據(jù)需要來定義(如CSV格式,也可以是xlsx結(jié)尾的格式),通常用于數(shù)據(jù)分析和傳輸。

舉例

1.場景: 有一個名為 employees 的數(shù)據(jù)庫,其中包含 staff 表。導(dǎo)出 staff 表中的數(shù)據(jù)作為CSV文件來分析。

2.步驟:

進(jìn)入 MySQL 客戶端。

執(zhí)行以下 SQL 語句:

SELECT * FROM staff INTO OUTFILE '/var/lib/mysql-files/staff_data.csv'
FIELDS TERMINATED BY ',' 
ENCLOSED BY '"'
LINES TERMINATED BY '\n';

命令解讀(也可以使用默認(rèn),后面就不用那么多指定要求語句了):
-- 從 staff 表中選擇所有列和行
SELECT * FROM staff 

-- 將查詢結(jié)果寫入指定路徑的文件中
INTO OUTFILE '/var/lib/mysql-files/staff_data.csv'

-- 每個字段(列)的數(shù)據(jù)使用逗號分隔
FIELDS TERMINATED BY ',' 

-- 每個字段的值都用雙引號包圍
ENCLOSED BY '"'

-- 每行記錄之間以換行符分隔
LINES TERMINATED BY '\n';

3.結(jié)果: 生成的 staff_data.csv 文件內(nèi)容:

    "1","Alice","Manager","50000"
    "2","Bob","Engineer","40000"
    "3","Charlie","Technician","30000"

恢復(fù):

  • 在新環(huán)境中,確保已存在相同結(jié)構(gòu)的 staff 表。
  • 復(fù)制 staff_data.csv 文件到服務(wù)器。
  • 使用以下 SQL 語句導(dǎo)入數(shù)據(jù):
      LOAD DATA INFILE '/var/lib/mysql-files/staff_data.csv'
      INTO TABLE staff
      FIELDS TERMINATED BY ',' 
      ENCLOSED BY '"'
      LINES TERMINATED BY '\n';

總結(jié)

用途不同:

  • mysqldump -n 主要用于備份和恢復(fù) MySQL 數(shù)據(jù)庫數(shù)據(jù)。生成 SQL 文件,便于在需要時恢復(fù)數(shù)據(jù)。
  • SELECT INTO OUTFILE 主要用于數(shù)據(jù)導(dǎo)出用于分析或傳輸。生成的文件格式如CSV,可用Excel等工具打開。

恢復(fù)指定表:

  • mysqldump -n 恢復(fù)數(shù)據(jù)更簡單,直接源文件加載到MySQL中即可。
  • SELECT INTO OUTFILE 導(dǎo)出的文件格式靈活,但需要額外步驟導(dǎo)入數(shù)據(jù)(如使用 LOAD DATA INFILE)。

便捷性和靈活性:

  • mysqldump -n 適用于跨平臺環(huán)境,恢復(fù)數(shù)據(jù)庫較為便捷。
  • SELECT INTO OUTFILE 適用于導(dǎo)出數(shù)據(jù)進(jìn)行外部分析,格式靈活但操作稍復(fù)雜。

到此這篇關(guān)于MySQL邏輯備份的實現(xiàn)步驟的文章就介紹到這了,更多相關(guān)MySQL邏輯備份內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • MySQL數(shù)據(jù)庫表內(nèi)容的增刪查改操作實例詳解

    MySQL數(shù)據(jù)庫表內(nèi)容的增刪查改操作實例詳解

    對于刪除操作來說,是將表單個或者多個數(shù)據(jù)進(jìn)行刪除,而截斷則是對整個表進(jìn)行操作,會將整個表數(shù)據(jù)都清除,本文給大家介紹MySQL數(shù)據(jù)庫表內(nèi)容的增刪查改操作大全,感興趣的朋友一起看看吧
    2025-04-04
  • mysql 5.7.5 m15 winx64安裝配置圖文教程

    mysql 5.7.5 m15 winx64安裝配置圖文教程

    這篇文章主要為大家分享了mysql 5.7.5 m15 winx64安裝配置方法圖文教程,感興趣的朋友可以參考一下
    2016-08-08
  • 解決MySQL客戶端輸出窗口顯示中文亂碼問題的辦法

    解決MySQL客戶端輸出窗口顯示中文亂碼問題的辦法

    這篇文章主要介紹了解決MySQL客戶端輸出窗口顯示中文亂碼問題的辦法,需要的朋友可以參考下
    2015-12-12
  • SQL優(yōu)化教程之in與range查詢

    SQL優(yōu)化教程之in與range查詢

    這篇文章主要介紹了給大家介紹了SQL優(yōu)化之in與range查詢的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • MySQL筆記之別名的使用

    MySQL筆記之別名的使用

    在查詢時,可以為表和字段取一個別名。這個別名可以代替其指定的表和字段
    2013-05-05
  • IDEA連接mysql時區(qū)問題解決

    IDEA連接mysql時區(qū)問題解決

    在使用MySQL數(shù)據(jù)庫時,經(jīng)常會遇到需要設(shè)置時區(qū)的情況,本文主要介紹了IDEA連接mysql時區(qū)問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • MySQL8.0新特性之支持原子DDL語句

    MySQL8.0新特性之支持原子DDL語句

    這MySQL 8.0開始支持原子數(shù)據(jù)定義語言(DDL)語句。此功能稱為原子DDL。這篇文章主要介紹了MySQL8.0新特性——支持原子DDL語句,需要的朋友可以參考下
    2018-07-07
  • 美團(tuán)DB數(shù)據(jù)同步到數(shù)據(jù)倉庫的架構(gòu)與實踐

    美團(tuán)DB數(shù)據(jù)同步到數(shù)據(jù)倉庫的架構(gòu)與實踐

    今天小編就為大家分享一篇關(guān)于美團(tuán)DB數(shù)據(jù)同步到數(shù)據(jù)倉庫的架構(gòu)與實踐,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • mysql查詢當(dāng)前時間的前幾分鐘、幾小時、幾天以及幾月的數(shù)據(jù)示例代碼

    mysql查詢當(dāng)前時間的前幾分鐘、幾小時、幾天以及幾月的數(shù)據(jù)示例代碼

    今天花了些時間整理了下MySQL中分別查找當(dāng)天、昨天、近一周、近一個月等等時間段數(shù)據(jù)的代碼,給大家分享下,這篇文章主要給大家介紹了關(guān)于如何利用mysql查詢當(dāng)前時間的前幾分鐘、幾小時、幾天以及幾月的數(shù)據(jù),需要的朋友可以參考下
    2024-01-01
  • MySQL regexp 命令詳解

    MySQL regexp 命令詳解

    REGEXP命令用于在查詢中進(jìn)行正則表達(dá)式匹配,支持多種符號和語法,如^、$、.、*、+、?、|、[]等,示例展示了如何匹配特定字符、數(shù)字、多個選項等,使用BINARY關(guān)鍵字可以區(qū)分大小寫,本文介紹MySQL regexp 命令,感興趣的朋友一起看看吧
    2025-03-03

最新評論