mysqldump 命令常用參數


---恢復內容開始---

1、--all-databases  , -A

導出全部數據庫

mysqldump  -h127.0.0.1 -uroot -ppasswd -A > all_db.sql

2、--all-tablespaces  , -Y

導出全部表空間。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  -Y > all_db.sql

3、--add-drop-database

每個數據庫創建之前添加drop數據庫語句。

mysqldump   -h127.0.0.1 -uroot -ppasswd  -A --add-drop-database  > all_db.sql

4、--add-drop-table

每個數據表創建之前添加drop數據表語句。(默認為打開狀態,使用--skip-add-drop-table取消選項)

mysqldump  -h127.0.0.1 -uroot -ppasswd  -A  (默認添加drop語句)

mysqldump  -h127.0.0.1 -uroot -ppasswd  -A   –skip-add-drop-table  (取消drop語句)

5、--add-locks

在每個表導出之前增加LOCK TABLES並且之后UNLOCK  TABLE。(默認為打開狀態,使用--skip-add-locks取消選項)

mysqldump  -h127.0.0.1 -uroot -ppasswd  -A  (默認添加LOCK語句)

mysqldump  -h127.0.0.1 -uroot -ppasswd  -A  –skip-add-locks   (取消LOCK語句)

6、--apply-slave-statements

在'CHANGE MASTER'前添加'STOP SLAVE',並且在導出的最后添加'START SLAVE'。

mysqldump   -h127.0.0.1 -uroot -ppasswd  -A  --apply-slave-statements

7、--character-sets-dir

字符集文件的目錄

mysqldump  -h127.0.0.1 -uroot -ppasswd  -A   --character-sets-dir=/data/mysql/share/charsets

8、--compress, -C

在客戶端和服務器之間啟用壓縮傳遞所有信息

mysqldump  -h127.0.0.1 -uroot -ppasswd  -A --compress

9、--databases,  -B

導出幾個數據庫。參數后面所有名字參量都被看作數據庫名。

mysqldump -h127.0.0.1 -uroot -ppasswd  -B test mysql

10、--default-character-set

設置默認字符集,默認值為utf8

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --default-character-set=latin1

11、--dump-slave

該選項將導致主的binlog位置和文件名追加到導出數據的文件中。設置為1時,將會以CHANGE MASTER命令輸出到數據文件;設置為2時,在命令前增加說明信息。該選項將會打開--lock-all-tables,除非--single-transaction被指定。該選項會自動關閉--lock-tables選項。默認值為0。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A --dump-slave=1

mysqldump  -h127.0.0.1 -uroot -ppasswd -A --dump-slave=2

12、-flush-logs

開始導出之前刷新日志。

請注意:假如一次導出多個數據庫(使用選項--databases或者--all-databases),將會逐個數據庫刷新日志。除使用--lock-all-tables或者--master-data外。在這種情況下,日志將會被刷新一次,相應的所以表同時被鎖定。因此,如果打算同時導出和刷新日志應該使用--lock-all-tables 或者--master-data 和--flush-logs。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --flush-logs

13、-flush-privileges

在導出mysql數據庫之后,發出一條FLUSH  PRIVILEGES 語句。為了正確恢復,該選項應該用於導出mysql數據庫和依賴mysql數據庫數據的任何時候。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --flush-privileges

14、--ignore-table

不導出指定表。指定忽略多個表時,需要重復多次,每次一個表。每個表必須同時指定數據庫和表名。

例如:--ignore-table=database.table1 --ignore-table=database.table2 ……

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --ignore-table=mysql.user

15、--include-master-host-port

在--dump-slave產生的'CHANGE  MASTER TO..'語句中增加'MASTER_HOST=<host>,MASTER_PORT=<port>'  

mysqldump -h127.0.0.1 -uroot -ppasswd -A   --include-master-host-port

16、--lock-all-tables,  -x

提交請求鎖定所有數據庫中的所有表,以保證數據的一致性。這是一個全局讀鎖,並且自動關閉--single-transaction 和--lock-tables 選項。

mysqldump -h127.0.0.1 -uroot -ppasswd -A  -x

17、--lock-tables,  -l

開始導出前,鎖定所有表。用READ  LOCAL鎖定表以允許MyISAM表並行插入。對於支持事務的表如InnoDB和BDB,使用--single-transaction,因為不需要鎖定表。

請注意當導出多個數據庫時,--lock-tables分別為每個數據庫鎖定表。因此,不能保證導出的表在數據庫之間的邏輯一致性。不同數據庫表的導出狀態可以完全不同。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  -l

18、--master-data

該選項將binlog的位置和文件名追加到輸出文件中。

如果為1,將會輸出CHANGE MASTER 命令;

如果為2,輸出的CHANGE  MASTER命令前添加注釋信息。

該選項將打開--lock-all-tables 選項,除非--single-transaction也被指定(在這種情況下,全局讀鎖在開始導出時獲得很短的時間;其他內容參考下面的--single-transaction選項)。該選項自動關閉--lock-tables選項。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A   --master-data=1;

mysqldump  -h127.0.0.1 -uroot -ppasswd -A   --master-data=2;

19、--no-create-db,  -n

只導出數據,而不添加CREATE DATABASE 語句。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A   --no-create-db

20、--no-create-info,  -t

只導出數據,而不添加CREATE TABLE 語句。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --no-create-info

21、--no-data, -d

不導出任何數據,只導出數據庫表結構。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  -d

22、--port, -P

連接數據庫端口號

23、--protocol

使用的連接協議,包括:tcp, socket, pipe, memory.

mysqldump  -h127.0.0.1 -uroot -ppasswd -A --protocol=tcp

24、--result-file,  -r

直接輸出到指定文件中。該選項應該用在使用回車換行對(\\r\\n)換行的系統上(例如:DOS,Windows)。該選項確保只有一行被使用。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --result-file=/tmp/mysqldump_result_file.txt

25、--routines, -R

導出存儲過程以及自定義函數。

mysqldump   -h127.0.0.1 -uroot -ppasswd -A  --routines

26、--single-transaction

該選項在導出數據之前提交一個BEGIN SQL語句,BEGIN 不會阻塞任何應用程序且能保證導出時數據庫的一致性狀態。它只適用於多版本存儲引擎,僅InnoDB。本選項和--lock-tables 選項是互斥的,因為LOCK  TABLES 會使任何掛起的事務隱含提交。要想導出大表的話,應結合使用--quick 選項。

mysqldump   -h127.0.0.1 -uroot -ppasswd -A   --single-transaction

27、--dump-date

將導出時間添加到輸出文件中。默認為打開狀態,使用--skip-dump-date關閉選項。

mysqldump   -h127.0.0.1 -uroot -ppasswd -A

mysqldump   -h127.0.0.1 -uroot -ppasswd -A --skip-dump-date

28、--socket,-S

指定連接mysql的socket文件位置,默認路徑/tmp/mysql.sock

mysqldump   -h127.0.0.1 -uroot -ppasswd -A  --socket=/tmp/mysqld.sock

29、--tables

覆蓋--databases (-B)參數,指定需要導出的表名。

mysqldump   -h127.0.0.1 -uroot -ppasswd -B  test --tables test

30、--tz-utc

在導出頂部設置時區TIME_ZONE='+00:00' ,以保證在不同時區導出的TIMESTAMP 數據或者數據被移動其他時區時的正確性。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --tz-utc

31、--verbose, --v

輸出多種平台信息。

32、--version, -V

輸出mysqldump版本信息並退出

33、--events, -E

導出事件。

mysqldump  -h127.0.0.1 -uroot -ppasswd -A  --events

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM