本文最后更新于 2024-07-06,文章内容可能已经过时。

mysqldump介绍

是mysql用于转存储数据库的实用程序。它主要产生一个SQL脚本,其中包含从头重新创建数据库所必需的命令CREATE TABLE INSERT等。:

  • 导出一个数据库的结构
mysqldump -d dbname -uroot -p > dbname.sql
  • 导出多个数据库的结构
mysqldump -d -B dbname1 dbname2 -uroot -p > dbname.sql
  • 导出一个数据库中数据(不包含结构)
mysqldump -t dbname -uroot -p > dbname.sql
  • 导出多个数据库中数据(不包含结构)
mysqldump -t -B dbname1 dbname2 -uroot -p > dbname.sql
  • 导出一个数据库的结构以及数据
mysqldump dbname -uroot -p > dbname.sql
  • 导出多个数据库的结构以及数据
mysqldump -B dbname1 dbname2 -uroot -p > dbname.sql
  • 导出一个数据库中一个表的结构
mysqldump -d dbname1 tablename -uroot -p > tablename.sql
  • 导出一个数据库中多个表的结构
mysqldump -d -B dbname1 --tables tablename1 tablename2 -uroot -p > tablename.sql
  • 导出一个数据库中一个表的数据(不包含结构)
mysqldump -t dbname1 tablename -uroot -p > tablename.sql
  • 导出一个数据库中多个表的数据(不包含结构)
mysqldump -t -B dbname1 --tables tablename1 tablename2 -uroot -p > tablename.sql
  • 导出一个数据库中一个表的结构以及数据
mysqldump dbname1 tablename -uroot -p > tablename.sql
  • 导出一个数据库中多个表的结构以及数据
mysqldump -B dbname1 --tables tablename1 tablename2 -uroot -p > tablename.sql

存储过程&函数操作

  • 只导出存储过程和函数(不导出结构和数据,要同时导出结构的话,需要同时使用 -d
mysqldump -R -ndt dbname -u root -p > dbname.sql
  • 只导出事件
mysqldump -E -ndt dbname -u root -p > dbname.sql
  • 不导出触发器(触发器是默认导出的–triggers,使用–skip-triggers屏蔽导出触发器)
mysqldump --skip-triggers dbname1 -u root -p > dbname.sql

总结


-d 结构(--no-data:不导出任何数据,只导出数据库表结构)

-t 数据(--no-create-info:只导出数据,而不添加CREATE TABLE 语句)

-n (--no-create-db:只导出数据,而不添加CREATE DATABASE 语句)

-R (--routines:导出存储过程以及自定义函数)

-E (--events:导出事件)

--triggers (默认导出触发器,使用--skip-triggers屏蔽导出)

-B (--databases:导出数据库列表,单个库时可省略)

--tables 表列表(单个表时可省略)

同时导出结构以及数据时可同时省略-d和-t
同时 不 导出结构和数据可使用-ntd
只导出存储过程和函数可使用-R -ntd
导出所有(结构&数据&存储过程&函数&事件&触发器)使用-R -E(相当于①,省略了-d -t;触发器默认导出)
只导出结构&函数&事件&触发器使用 -R -E -d