日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

MySQL 復制表的方法

瀏覽:86日期:2023-10-05 10:15:12
1、mysqldump執行過程:

一、將數據導出為 sql 文件。

mysqldump -h$host -P$port -u$user --add-locks=0 --no-create-info --single-transaction --set-gtid-purged=OFF db1 t --where='a>900' --result-file=/client_tmp/t.sql

將數據導出為 sql 文件保存。上面幾個參數的含義分別是:

1、?single-transaction 的作用是,在導出數據的時候不需要對表 db1.t 加表鎖,而是使用 START TRANSACTION WITH CONSISTENT SNAPSHOT 的方法;

2、?add-locks 設置為 0,表示在輸出的文件結果里,不增加' LOCK TABLES t WRITE;' ;

3、?no-create-info 的意思是,不需要導出表結構;

4、?set-gtid-purged=off 表示的是,不輸出跟 GTID 相關的信息;

5、?result-file 指定了輸出文件的路徑,其中 client 表示生成的文件是在客戶端機器上的。

二、執行文件,添加到表中

mysql -h127.0.0.1 -P13000 -uroot db2 -e 'source /client_tmp/t.sql'

source 并不是一條 SQL 語句,而是一個客戶端命令。也就是服務器端具體執行的是文件中的一條條 sql 語句,所以 binlog 記錄的都是具體的 sql。

特點

1、生成的 sql 文件保存在客戶端

2、默認保存數據方式是多個記錄對,如下面格式

MySQL 復制表的方法

如果想要保存為一條語句只保存一條記錄,那么可以加上參數?skip-extended-insert。

2、導出 CSV 文件(最靈活)執行過程

一、導出為 CSV 文件

select * from db1.t where a>900 into outfile ’/server_tmp/t.csv’;

注意:

1、into outfile 指定了文件的生成位置(/server_tmp/),這個位置必須受參數 secure_file_priv 的限制。

參數 secure_file_priv 的可選值和作用分別是:

1)如果設置為 empty,表示不限制文件生成的位置,這是不安全的設置;

2)如果設置為一個表示路徑的字符串,就要求生成的文件只能放在這個指定的目錄,或者它的子目錄;

3)如果設置為 NULL,就表示禁止在這個 MySQL 實例上執行 select … into outfile 操作。

2、如果同一個目錄下存在同名文件,就會報錯

3、一般情況下一條記錄就對應 CSV 文件中的一行,但是如果某個字段值中有 '換行、制表符' 那么文件中也會包含,并且使用 '' 來轉義。

二、導入數據

load data infile ’/server_tmp/t.csv’ into table db2.t;

過程:

1、打開文件 /server_tmp/t.csv,以制表符 (t) 作為字段間的分隔符,以換行符(n)作為記錄之間的分隔符,進行數據讀取;

2、啟動事務。

3、判斷每一行的字段數與表 db2.t 是否相同:

1)若不相同,則直接報錯,事務回滾;

2)若相同,則構造成一行,調用 InnoDB 引擎接口,寫入到表中。

4、重復步驟 3,直到 /server_tmp/t.csv 整個文件讀入完成,提交事務。

特點

1、文件保存在服務器端

2、關于 binlog 的記錄,過程如下:

1)主庫執行完成后,將 /server_tmp/t.csv 文件的內容直接寫到 binlog 文件中。

2)往 binlog 文件中寫入語句 load data local infile ‘/tmp/SQL_LOAD_MB-1-0’ INTO TABLE `db2`.`t`。

3)把這個 binlog 日志傳到備庫。

4)備庫的 apply 線程在執行這個事務日志時:

a. 先將 binlog 中 t.csv 文件的內容讀出來,寫入到本地臨時目錄 /tmp/SQL_LOAD_MB-1-0 中;

b. 再執行 load data 語句,往備庫的 db2.t 表中插入跟主庫相同的數據。

MySQL 復制表的方法

關于 'local':

1)不加“local”,是讀取服務端的文件,這個文件必須在 secure_file_priv 指定的目錄或子目錄下;

2)加上“local”,讀取的是客戶端的文件,只要 mysql 客戶端有訪問這個文件的權限即可。這時候,MySQL 客戶端會先把本地文件傳給服務端(其他會話涉及的操作),然后執行上述的 load data 流程。

3、上面的導出操作并不會導出表結構,所以,如果向導出表結構,可以使用 mysqldump 來同時導出 CSV 和表結構

mysqldump -h$host -P$port -u$user --single-transaction --set-gtid-purged=OFF db1 t --where='a>900' --tab=$secure_file_priv

會在$secure_file_priv 定義的目錄下,創建一個 t.sql 文件保存建表語句,同時創建一個 t.txt 文件保存 CSV 數據。

3、物理拷貝(最快)

在5.6之前,想要直接把.frm和.ibd文件拷貝到要拷貝的目錄下是不行的,因為一個Innodb表除了需要這兩個文件還需要在數據字典中注冊。但是從 5.6 開始可以解決這一問題,在 5.6 引入了可傳輸空間,可以通過導出 + 導入表空間來實現拷貝

過程

假設我們現在的目標是在 db1 庫下,復制一個跟表 t 相同的表 r,具體的執行步驟如下:

1、執行 create table r like t,創建一個相同表結構的空表;

2、執行 alter table r discard tablespace,這時候 r.ibd 文件會被刪除;

3、執行 flush table t for export,這時候 db1 目錄下會生成一個 t.cfg 文件;

4、在 db1 目錄下執行 cp t.cfg r.cfg; cp t.ibd r.ibd;這兩個命令(這里需要注意的是,拷貝得到的兩個文件,MySQL 進程要有讀寫權限);

5、執行 unlock tables,這時候 t.cfg 文件會被刪除;

6、執行 alter table r import tablespace,將這個 r.ibd 文件作為表 r 的新的表空間,由于這個文件的數據內容和 t.ibd 是相同的,所以表 r 中就有了和表 t 相同的數據。

MySQL 復制表的方法

注意:

1、在第 3 步執行完 flsuh table 命令之后,db1.t 整個表處于只讀狀態,直到執行 unlock tables 命令后才釋放讀鎖;

2、在執行 import tablespace 的時候,為了讓文件里的表空間 id 和數據字典中的一致,會修改 r.ibd 的表空間 id。而這個表空間 id 存在于每一個數據頁中。因此,如果是一個很大的文件(比如 TB 級別),每個數據頁都需要修改,所以你會看到這個 import 語句的執行是需要一些時間的。當然,如果是相比于邏輯導入的方法,import 語句的耗時是非常短的。

局限

1、必須是全表拷貝,不能條件拷貝

2、需要到服務器上拷貝數據,在用戶無法登錄數據庫主機的場景下無法使用

3、由于是通過拷貝物理文件實現的,源表和目標表都是使用 InnoDB 引擎時才能使用

總結

1、前兩個都是邏輯備份,也就是可以跨引擎使用,最后一個不行

2、前兩個可以條件拷貝,最后一個不行

3、第二個功能是最靈活的,但是在集群從庫接收時會比較耗時(需要先拷貝 CSV 文件數據到本地臨時文件),最后一個執行效率是最高的,但是不能跨引擎,且只能進行全量拷貝。

以上就是MySQL 復制表的方法的詳細內容,更多關于MySQL 復制表的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩成人精品一区| 国产精品网址| 久久精品网址| 久久影院资源站| 国产精品午夜av| 国产高清亚洲| 成人污污视频| 视频福利一区| 免费久久久久久久久| 黑丝一区二区三区| 男人的天堂久久精品| 日韩**一区毛片| 国产乱人伦精品一区| 麻豆精品久久久| 国产一二在线播放| 欧美日韩亚洲在线观看| 亚洲欧美日韩国产一区二区| 亚洲一区亚洲| 一区二区三区四区在线观看国产日韩| 亚洲香蕉久久| 国产精品一国产精品k频道56| 国产精品a久久久久| 98精品视频| 国产一区二区精品| 日韩av不卡一区二区| 久久久国产精品入口麻豆| 亚洲三级欧美| 午夜久久黄色| 日本一区二区三区视频在线看| 国产欧美一区二区三区米奇| 精品在线网站观看| 久久精品影视| 羞羞答答国产精品www一本| 日本精品国产| 一区二区三区四区日本视频| 99在线|亚洲一区二区| 日韩av网站在线观看| 黄毛片在线观看| 99在线观看免费视频精品观看| 日韩和欧美的一区| 国产v日韩v欧美v| 丝袜美腿成人在线| 欧美国产免费| 亚洲欧洲另类| 国产精品啊v在线| 欧美1区2区3区| 久久激情综合网| 欧美成人a交片免费看| 先锋影音久久久| 欧美黑人巨大videos精品| 欧美丝袜一区| 91精品丝袜国产高跟在线| 国产 日韩 欧美一区| 一区二区三区国产在线| 久久亚洲道色| 男人天堂欧美日韩| 国产suv精品一区| 午夜久久av| 99久久夜色精品国产亚洲狼| 国产一区 二区| 激情综合网站| 麻豆一区二区99久久久久| 丝袜诱惑制服诱惑色一区在线观看 | 精品三级在线| 蜜桃视频在线观看一区二区| 久久精品国产一区二区| 亚洲狼人精品一区二区三区| 国产videos久久| 亚洲精品进入| 亚洲一本视频| 高清日韩欧美| 欧美视频久久| 欧美美女一区| 免费在线成人| 亚洲精品国模| 午夜欧美视频| 国产va在线视频| 91免费精品国偷自产在线在线| 激情欧美一区| 国产精品久久久久蜜臀| 91精品丝袜国产高跟在线| 日韩国产高清在线| 国产女人18毛片水真多18精品| 视频一区二区中文字幕| 国产精品探花在线观看| 蜜臀av免费一区二区三区| 日韩欧美网址| 日本免费在线视频不卡一不卡二| 日韩毛片视频| 国产精品白丝久久av网站| 天堂av在线一区| 日本精品影院| 麻豆中文一区二区| 日本精品另类| 视频一区二区不卡| 久久免费国产| 国产成人久久精品麻豆二区 | 99国产精品99久久久久久粉嫩| 国产精品久久久久久久免费观看| 日韩精品免费视频人成| 五月婷婷亚洲| 欧美日韩国产在线观看网站| 日韩精品网站| 伊人久久视频| 最近高清中文在线字幕在线观看1| 免费在线亚洲欧美| 国产精选一区| 国产精品亲子伦av一区二区三区| 日本欧美在线| 亚洲精品精选| 无码日韩精品一区二区免费| 免费在线观看不卡| 久久成人亚洲| 天使萌一区二区三区免费观看| 成人av动漫在线观看| 久久人人99| 久久精品国产大片免费观看| 日韩成人亚洲| 亚洲一级特黄| 欧美日韩视频一区二区三区| 国产一区亚洲| 免费毛片在线不卡| 国产精品三上| 亚洲精选成人| 日本电影久久久| 日本在线成人| 国产日韩在线观看视频| 国产女人18毛片水真多18精品| 国产精品一区二区三区美女| 国产精选久久| 麻豆视频一区| 波多视频一区| 99久久久国产精品美女| 香蕉久久精品| 丝袜美腿一区二区三区| 四虎精品一区二区免费| 欧美久久香蕉| 久久精品国产福利| 91看片一区| 国产视频一区免费看| 伊人精品久久| 国产免费av一区二区三区| 精品国产中文字幕第一页| 午夜影院一区| 九九在线精品| 亚洲欧美久久| 欧美日本不卡高清| 福利视频一区| 一级欧洲+日本+国产| 亚洲视频二区| 国产精品一国产精品k频道56| 韩日一区二区| 国产成人精品一区二区三区免费 | 国产一区二区三区四区| zzzwww在线看片免费| 99精品视频在线| 亚洲三区欧美一区国产二区| 国产精品网站在线看| 日本а中文在线天堂| 婷婷综合亚洲| 欧美在线91| 成人亚洲一区二区| 午夜免费一区| 国产日产一区| 伊人久久国产| 香蕉久久国产| 国产精品久久久久久久久免费高清| 精品国产美女a久久9999| 91九色精品国产一区二区| 日韩精品亚洲专区| 欧洲av不卡| 日韩专区视频网站| 裤袜国产欧美精品一区| 国产毛片一区| 国产精区一区二区| 99久久精品国产亚洲精品| 日韩**一区毛片| caoporn视频在线| 亚洲天堂日韩在线| 极品av在线| 综合激情婷婷| 欧美香蕉视频| 亚洲97av| 久久久久久美女精品| 91精品福利观看| 激情自拍一区| 国产亚洲第一伦理第一区| 欧美色图国产精品| 国产情侣一区在线| 在线综合亚洲| 精品国产午夜| 亚洲精品一级| 日韩黄色大片网站| 欧美日韩一区自拍| 欧美精品一卡| 激情黄产视频在线免费观看| 奇米色欧美一区二区三区| se01亚洲视频| 久久gogo国模啪啪裸体| 先锋亚洲精品|