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

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

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

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

一.mysqldump

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

基本命令:

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

參數(shù)選項(xiàng):

  • -u, --user=[name]:指定 MySQL 用戶名。
  • -p, --password[=password]:指定 MySQL 密碼。如果不提供密碼,mysqldump 會(huì)提示輸入。
  • -h, --host=[hostname]:指定 MySQL 服務(wù)器主機(jī)名。
  • -P, --port=[port_num]:指定 MySQL 服務(wù)器端口號(hào)。
  • --protocol=[{TCP|SOCKET|PIPE|MEMORY}]:指定連接協(xié)議。
  • -r, --result-file=[file]:將輸出直接寫入文件,而不是通過(guò)標(biāo)準(zhǔn)輸出。
  • -t, --no-create-info:不寫入創(chuàng)建表的語(yǔ)句,只導(dǎo)出數(shù)據(jù)。
  • -d, --no-data:不寫入數(shù)據(jù),只導(dǎo)出數(shù)據(jù)庫(kù)結(jié)構(gòu)。
  • --add-drop-table:在每個(gè)創(chuàng)建表語(yǔ)句前增加 DROP TABLE IF EXISTS 語(yǔ)句。
  • --add-locks:在插入數(shù)據(jù)前后使用 LOCK TABLES 和 UNLOCK TABLES 語(yǔ)句。
  • --disable-keys:在插入數(shù)據(jù)前使用 ALTER TABLE ... DISABLE KEYS,插入數(shù)據(jù)后使用 ALTER TABLE ... ENABLE KEYS
  • -B, --databases:指定要備份的數(shù)據(jù)庫(kù)。如果使用該選項(xiàng),所有跟在其后的數(shù)據(jù)庫(kù)名都將被備份。
  • -A, --all-databases:備份所有數(shù)據(jù)庫(kù)。
  • --tables:指定要備份的表,必須跟在數(shù)據(jù)庫(kù)名之后。
  • -n, --no-create-db:不寫入創(chuàng)建數(shù)據(jù)庫(kù)的語(yǔ)句。
  • -w, --where='condition':僅導(dǎo)出符合指定條件的行。
  • --single-transaction:在一個(gè)事務(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)出存儲(chǔ)過(guò)程和函數(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ù)制。

示例

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

mysqldump -u root -p mydatabase > mydatabase_backup.sql

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

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

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

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

僅備份數(shù)據(jù)庫(kù)結(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

添加選項(xiàng)以有效處理鎖表問(wèn)題

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

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

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

語(yǔ)法

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

示例

mysql -u root -p mydatabase < mydatabase_backup.sql

恢復(fù)庫(kù)中的表 

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

使用source恢復(fù) 

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

source 文件路徑;

例: 

source /path/to/employees_backup.sql;

注意事項(xiàng)

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

二. mysqlpump

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

mysqlpump 特點(diǎn)

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

基本命令:

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

常用選項(xiàng):

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

示例

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

mysqlpump -u root -p mydatabase > mydatabase_backup.sql

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

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

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

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ù),加快備份速度。 

過(guò)濾表

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 備份存儲(chǔ)函數(shù)和存儲(chǔ)過(guò)程。

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

解壓縮備份文件

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

恢復(fù)備份

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

示例

mysql -u root -p mydatabase < mydatabase_backup.sql

注意事項(xiàng)

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

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

優(yōu)點(diǎn)

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

缺點(diǎn)

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

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

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

mysqldump -n

介紹

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

舉例

場(chǎng)景: 有一個(gè)名為 employees 的數(shù)據(jù)庫(kù),其中包含 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語(yǔ)句,用于將查詢結(jié)果導(dǎo)出到文件中。文件格式可以根據(jù)需要來(lái)定義(如CSV格式,也可以是xlsx結(jié)尾的格式),通常用于數(shù)據(jù)分析和傳輸。

舉例

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

2.步驟:

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

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

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

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

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

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

-- 每個(gè)字段的值都用雙引號(hào)包圍
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 語(yǔ)句導(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ù)庫(kù)數(shù)據(jù)。生成 SQL 文件,便于在需要時(shí)恢復(fù)數(shù)據(jù)。
  • SELECT INTO OUTFILE 主要用于數(shù)據(jù)導(dǎo)出用于分析或傳輸。生成的文件格式如CSV,可用Excel等工具打開(kāi)。

恢復(fù)指定表:

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

便捷性和靈活性:

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

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

相關(guān)文章

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

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

    對(duì)于刪除操作來(lái)說(shuō),是將表單個(gè)或者多個(gè)數(shù)據(jù)進(jìn)行刪除,而截?cái)鄤t是對(duì)整個(gè)表進(jìn)行操作,會(huì)將整個(gè)表數(shù)據(jù)都清除,本文給大家介紹MySQL數(shù)據(jù)庫(kù)表內(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客戶端輸出窗口顯示中文亂碼問(wèn)題的辦法

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

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

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

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

    MySQL筆記之別名的使用

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

    IDEA連接mysql時(shí)區(qū)問(wèn)題解決

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

    MySQL8.0新特性之支持原子DDL語(yǔ)句

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

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

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

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

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

    MySQL regexp 命令詳解

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

最新評(píng)論