---恢復內容開始---
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