mysqldump 客户端实用程序执行 逻辑备份,生成一组 SQL 语句,可以执行这些语句来复制原始数据库对象定义和表数据。它转储一个或多个 MySQL 数据库以进行备份或传输到另一个 SQL 服务器。mysqldump 命令还可以生成 CSV、其他分隔文本或 XML 格式的输出。
考虑使用 MySQL Shell 转储实用程序,它们提供多线程并行转储、文件压缩和进度信息显示,以及云功能,如 Oracle 云基础设施对象存储流式传输,以及 MySQL HeatWave 服务兼容性检查和修改。可以使用 MySQL Shell 加载转储实用程序轻松地将转储导入 MySQL 服务器实例或 MySQL HeatWave 服务数据库系统。MySQL Shell 的安装说明可以在此处找到。
mysqldump 至少需要对转储表具有 SELECT
权限,对转储视图具有 SHOW VIEW
权限,对转储触发器具有 TRIGGER
权限,如果未使用 --single-transaction
选项,则需要 LOCK TABLES
权限,如果未使用 --no-tablespaces
选项,则需要 PROCESS
权限,如果同时使用了 --single-transaction
、gtid_mode=ON
和 gtid_purged=ON|AUTO
,则需要 RELOAD
或 FLUSH_TABLES
权限。某些选项可能需要其他权限,如选项说明中所述。
要重新加载转储文件,您必须拥有执行其包含的语句所需的权限,例如对这些语句创建的对象具有适当的 CREATE
权限。
mysqldump 输出可以包含更改数据库排序规则的 ALTER DATABASE
语句。这些语句可以在转储存储程序时使用,以保留其字符编码。要重新加载包含此类语句的转储文件,需要对受影响的数据库具有 ALTER
权限。
在 Windows 上使用 PowerShell 并进行输出重定向创建的转储文件使用 UTF-16 编码
mysqldump [options] > dump.sql
但是,UTF-16 不允许作为连接字符集(请参阅 不允许的客户端字符集),因此无法正确加载转储文件。要解决此问题,请使用 --result-file
选项,该选项以 ASCII 格式创建输出
mysqldump [options] --result-file=dump.sql
如果在服务器上启用了 GTID (gtid_mode=ON
),并且您的转储文件包含系统表,则不建议加载转储文件。mysqldump 会为使用非事务性 MyISAM 存储引擎的系统表发出 DML 指令,并且在启用 GTID 时不允许这种组合。
性能和可扩展性注意事项
mysqldump
的优点包括在恢复之前查看甚至编辑输出的便利性和灵活性。您可以克隆数据库以供开发和 DBA 工作,或者生成现有数据库的略微变体以进行测试。它不打算作为备份大量数据的快速或可扩展解决方案。对于大型数据集,即使备份步骤花费的时间合理,恢复数据也可能非常慢,因为重播 SQL 语句涉及用于插入、索引创建等的磁盘 I/O。
对于大规模备份和恢复,物理 备份更合适,可以原始格式复制数据文件,以便可以快速恢复。
如果您的表主要是 InnoDB
表,或者您同时拥有 InnoDB
和 MyISAM
表,请考虑使用 mysqlbackup,它是 MySQL 企业版的一部分。该工具以最小的中断为 InnoDB
备份提供了高性能;它还可以备份 MyISAM
和其他存储引擎中的表;它还提供许多方便的选项来适应不同的备份场景。请参阅 第 32.1 节 “MySQL 企业备份概述”。
mysqldump 可以逐行检索和转储表内容,也可以从表中检索整个内容并在转储之前将其缓冲到内存中。 如果您要转储大型表,则在内存中进行缓冲可能会出现问题。 要逐行转储表,请使用 --quick
选项(或 --opt
,它会启用 --quick
)。 默认情况下启用 --opt
选项(因此也启用了 --quick
),因此要启用内存缓冲,请使用 --skip-quick
。
如果您使用的是最新版本的 mysqldump 来生成要重新加载到非常旧的 MySQL 服务器的转储,请使用 --skip-opt
选项,而不是 --opt
或 --extended-insert
选项。
有关 mysqldump 的其他信息,请参阅第 9.4 节,“使用 mysqldump 进行备份”。
调用语法
通常,可以使用三种方法来使用 mysqldump,以便转储一组一个或多个表、一组一个或多个完整的数据库或整个 MySQL 服务器,如下所示
mysqldump [options] db_name [tbl_name ...]
mysqldump [options] --databases db_name ...
mysqldump [options] --all-databases
要转储整个数据库,请勿在 db_name
后面命名任何表,或使用 --databases
或 --all-databases
选项。
要查看您的 mysqldump 版本支持的选项列表,请发出命令 mysqldump --help
。
选项语法 - 按字母顺序排序的摘要
mysqldump 支持以下选项,这些选项可以在命令行或选项文件的 [mysqldump]
和 [client]
组中指定。 有关 MySQL 程序使用的选项文件的信息,请参阅第 6.2.2.2 节,“使用选项文件”。
表 6.13 mysqldump 选项
选项名称 | 描述 |
---|---|
--add-drop-database | 在每个 CREATE DATABASE 语句之前添加 DROP DATABASE 语句 |
--add-drop-table | 在每个 CREATE TABLE 语句之前添加 DROP TABLE 语句 |
--add-drop-trigger | 在每个 CREATE TRIGGER 语句之前添加 DROP TRIGGER 语句 |
--add-locks | 使用 LOCK TABLES 和 UNLOCK TABLES 语句包围每个表转储 |
--all-databases | 转储所有数据库中的所有表 |
--allow-keywords | 允许创建作为关键字的列名 |
--apply-replica-statements | 在 CHANGE REPLICATION SOURCE TO 语句之前包含 STOP REPLICA,并在输出结束时包含 START REPLICA |
--apply-slave-statements | 在 CHANGE MASTER 语句之前包含 STOP SLAVE,并在输出结束时包含 START SLAVE |
--bind-address | 使用指定的网络接口连接到 MySQL 服务器 |
--character-sets-dir | 安装字符集的目录 |
--column-statistics | 编写 ANALYZE TABLE 语句以生成统计直方图 |
--comments | 向转储文件添加注释 |
--compact | 生成更紧凑的输出 |
--compatible | 生成与其他数据库系统或旧版 MySQL 服务器更兼容的输出 |
--complete-insert | 使用包含列名的完整 INSERT 语句 |
--compress | 压缩客户端和服务器之间发送的所有信息 |
--compression-algorithms | 连接到服务器时允许使用的压缩算法 |
--create-options | 在 CREATE TABLE 语句中包含所有 MySQL 特定的表选项 |
--databases | 将所有名称参数解释为数据库名称 |
--debug | 编写调试日志 |
--debug-check | 程序退出时打印调试信息 |
--debug-info | 程序退出时打印调试信息、内存和 CPU 统计信息 |
--default-auth | 要使用的身份验证插件 |
--default-character-set | 指定默认字符集 |
--defaults-extra-file | 除了常规选项文件外,还要读取指定的选项文件 |
--defaults-file | 仅读取指定的选项文件 |
--defaults-group-suffix | 选项组后缀值 |
--delete-master-logs | 在复制源服务器上,执行转储操作后删除二进制日志 |
--delete-source-logs | 在复制源服务器上,执行转储操作后删除二进制日志 |
--disable-keys | 对于每个表,使用禁用和启用键的语句包围 INSERT 语句 |
--dump-date | 如果给定了 --comments,则将转储日期作为“转储完成时间”注释包含在内 |
--dump-replica | 包含 CHANGE REPLICATION SOURCE TO 语句,该语句列出了副本源的二进制日志坐标 |
--dump-slave | 包含 CHANGE MASTER 语句,该语句列出了副本源的二进制日志坐标 |
--enable-cleartext-plugin | 启用明文身份验证插件 |
--events | 从转储的数据库中转储事件 |
--extended-insert | 使用多行 INSERT 语法 |
--fields-enclosed-by | 此选项与 --tab 选项一起使用,其含义与 LOAD DATA 的相应子句相同 |
--fields-escaped-by | 此选项与 --tab 选项一起使用,其含义与 LOAD DATA 的相应子句相同 |
--fields-optionally-enclosed-by | 此选项与 --tab 选项一起使用,其含义与 LOAD DATA 的相应子句相同 |
--fields-terminated-by | 此选项与 --tab 选项一起使用,其含义与 LOAD DATA 的相应子句相同 |
--flush-logs | 在开始转储之前刷新 MySQL 服务器日志文件 |
--flush-privileges | 在转储 mysql 数据库后发出 FLUSH PRIVILEGES 语句 |
--force | 即使在表转储期间发生 SQL 错误,也要继续 |
--get-server-public-key | 从服务器请求 RSA 公钥 |
--help | 显示帮助消息并退出 |
--hex-blob | 使用十六进制表示法转储二进制列 |
--host | MySQL 服务器所在的主机 |
--ignore-error | 忽略指定的错误 |
--ignore-table | 不转储给定的表 |
--ignore-views | 跳过转储表视图 |
--include-master-host-port | 在使用 --dump-slave 生成的 CHANGE MASTER 语句中包含 MASTER_HOST/MASTER_PORT 选项 |
--include-source-host-port | 在使用 --dump-replica 生成的 CHANGE REPLICATION SOURCE TO 语句中包含 SOURCE_HOST 和 SOURCE_PORT 选项 |
--init-command | 连接或重新连接到 MySQL 服务器后要执行的单个 SQL 语句;重置现有的已定义命令 |
--init-command-add | 添加一个额外的 SQL 语句,该语句在连接或重新连接到 MySQL 服务器后执行 |
--insert-ignore | 编写 INSERT IGNORE 语句而不是 INSERT 语句 |
--lines-terminated-by | 此选项与 --tab 选项一起使用,其含义与 LOAD DATA 的相应子句相同 |
--lock-all-tables | 锁定所有数据库中的所有表 |
--lock-tables | 在转储所有表之前锁定它们 |
--log-error | 将警告和错误附加到指定的文件 |
--login-path | 从 .mylogin.cnf 读取登录路径选项 |
--master-data | 将二进制日志文件名和位置写入输出 |
--max-allowed-packet | 要发送到服务器或从服务器接收的最大数据包长度 |
--mysqld-long-query-time | 慢查询阈值的会话值 |
--net-buffer-length | TCP/IP 和套接字通信的缓冲区大小 |
--network-timeout | 增加网络超时以允许更大的表转储 |
--no-autocommit | 将每个转储表的 INSERT 语句括在 SET autocommit = 0 和 COMMIT 语句中 |
--no-create-db | 不编写 CREATE DATABASE 语句 |
--no-create-info | 不编写重新创建每个转储表的 CREATE TABLE 语句 |
--no-data | 不转储表内容 |
--no-defaults | 不读取选项文件 |
--no-login-paths | 不从登录路径文件读取登录路径 |
--no-set-names | 与 --skip-set-charset 相同 |
--no-tablespaces | 不在输出中编写任何 CREATE LOGFILE GROUP 或 CREATE TABLESPACE 语句 |
--opt | --add-drop-table --add-locks --create-options --disable-keys --extended-insert --lock-tables --quick --set-charset 的简写 |
--order-by-primary | 按主键或第一个唯一索引对每个表的行进行排序 |
--output-as-version | 确定转储中使用的副本和事件术语;为了与旧版本兼容 |
--password | 连接到服务器时使用的密码 |
--password1 | 连接到服务器时使用的第一个多重身份验证密码 |
--password2 | 连接到服务器时使用的第二个多重身份验证密码 |
--password3 | 连接到服务器时使用的第三个多重身份验证密码 |
--pipe | 使用命名管道连接到服务器(仅限 Windows) |
--plugin-authentication-kerberos-client-mode | 允许在 Windows 上通过 MIT Kerberos 库进行 GSSAPI 可插拔身份验证 |
--plugin-dir | 安装插件的目录 |
--port | 用于连接的 TCP/IP 端口号 |
--print-defaults | 打印默认选项 |
--protocol | 要使用的传输协议 |
--quick | 一次从服务器检索表的一行 |
--quote-names | 用反引号将标识符引起来 |
--replace | 编写 REPLACE 语句而不是 INSERT 语句 |
--result-file | 将输出直接定向到给定的文件 |
--routines | 从转储的数据库中转储存储例程(过程和函数) |
--server-public-key-path | 包含 RSA 公钥的文件的路径名 |
--set-charset | 将 SET NAMES default_character_set 添加到输出中 |
--set-gtid-purged | 是否将 SET @@GLOBAL.GTID_PURGED 添加到输出中 |
--shared-memory-base-name | 用于共享内存连接的共享内存名称(仅限 Windows) |
--show-create-skip-secondary-engine | 从 CREATE TABLE 语句中排除 SECONDARY ENGINE 子句 |
--single-transaction | 在从服务器转储数据之前发出 BEGIN SQL 语句 |
--skip-add-drop-table | 不在每个 CREATE TABLE 语句之前添加 DROP TABLE 语句 |
--skip-add-locks | 不添加锁 |
--skip-comments | 不向转储文件添加注释 |
--skip-compact | 不生成更紧凑的输出 |
--skip-disable-keys | 不禁用键 |
--skip-extended-insert | 关闭 extended-insert |
--skip-generated-invisible-primary-key | 不在转储文件中包含生成的不可见主键 |
--skip-opt | 关闭 --opt 设置的选项 |
--skip-quick | 不要一次从服务器检索表的一行 |
--skip-quote-names | 不引用标识符 |
--skip-set-charset | 不编写 SET NAMES 语句 |
--skip-triggers | 不转储触发器 |
--skip-tz-utc | 关闭 tz-utc |
--socket | 要使用的 Unix 套接字文件或 Windows 命名管道 |
--source-data | 将二进制日志文件名和位置写入输出 |
--ssl-ca | 包含受信任的 SSL 证书颁发机构列表的文件 |
--ssl-capath | 包含受信任的 SSL 证书颁发机构证书文件的目录 |
--ssl-cert | 包含 X.509 证书的文件 |
--ssl-cipher | 允许用于连接加密的密码 |
--ssl-fips-mode | 是否在客户端启用 FIPS 模式 |
--ssl-key | 包含 X.509 密钥的文件 |
--ssl-mode | 与服务器连接的所需安全状态 |
--ssl-session-data | 包含 SSL 会话数据的文件 |
--ssl-session-data-continue-on-failed-reuse | 如果会话重用失败,是否建立连接 |
--tab | 生成制表符分隔的数据文件 |
--tables | 覆盖 --databases 或 -B 选项 |
--tls-ciphersuites | 加密连接允许的 TLSv1.3 密码套件 |
--tls-sni-servername | 客户端提供的服务器名称 |
--tls-version | 加密连接允许的 TLS 协议 |
--triggers | 转储每个转储表的触发器 |
--tz-utc | 将 SET TIME_ZONE='+00:00' 添加到转储文件 |
--user | 连接到服务器时使用的 MySQL 用户名 |
--verbose | 详细模式 |
--version | 显示版本信息并退出 |
--where | 仅转储由给定 WHERE 条件选择的行 |
--xml | 生成 XML 输出 |
--zstd-compression-level | 使用 zstd 压缩的服务器连接的压缩级别 |
连接选项
mysqldump 命令登录到 MySQL 服务器以提取信息。以下选项指定如何连接到 MySQL 服务器,无论是在同一台机器上还是在远程系统上。
-
命令行格式 --bind-address=ip_address
在具有多个网络接口的计算机上,使用此选项可以选择用于连接到 MySQL 服务器的接口。
--compress
,-C
命令行格式 --compress[={OFF|ON}]
已弃用 是 类型 布尔值 默认值 OFF
如果可能,压缩客户端和服务器之间发送的所有信息。请参阅 第 6.2.8 节,“连接压缩控制”。
此选项已弃用。预计在未来版本的 MySQL 中会被删除。请参阅 配置旧版连接压缩。
--compression-algorithms=
value
命令行格式 --compression-algorithms=value
类型 设置 默认值 未压缩
有效值 zlib
zstd
未压缩
允许的服务器连接压缩算法。可用算法与
protocol_compression_algorithms
系统变量相同。默认值为uncompressed
。有关更多信息,请参阅 第 6.2.8 节,“连接压缩控制”。
-
命令行格式 --default-auth=plugin
类型 字符串 有关使用哪个客户端身份验证插件的提示。请参阅 第 8.2.17 节,“可插拔身份验证”。
-
命令行格式 --enable-cleartext-plugin
类型 布尔值 默认值 FALSE
启用
mysql_clear_password
明文身份验证插件。(请参阅 第 8.4.1.3 节,“客户端明文可插拔身份验证”。) -
命令行格式 --get-server-public-key
类型 布尔值 从服务器请求基于 RSA 密钥对的密码交换所需的公钥。此选项适用于使用
caching_sha2_password
身份验证插件进行身份验证的客户端。对于该插件,除非请求,否则服务器不会发送公钥。对于未使用该插件进行身份验证的帐户,将忽略此选项。如果未使用基于 RSA 的密码交换(例如当客户端使用安全连接连接到服务器时),也会忽略此选项。如果给出了
--server-public-key-path=
并指定了有效的公钥文件,则它优先于file_name
--get-server-public-key
。有关
caching_sha2_password
插件的信息,请参阅 第 8.4.1.1 节,“缓存 SHA-2 可插拔身份验证”。 --host=
,host_name
-h
host_name
命令行格式 --host
从给定主机上的 MySQL 服务器转储数据。默认主机为
localhost
。-
命令行格式 --login-path=name
类型 字符串 从
.mylogin.cnf
登录路径文件中的命名登录路径读取选项。““登录路径” 是一个选项组,其中包含指定要连接到的 MySQL 服务器以及要作为哪个帐户进行身份验证的选项。要创建或修改登录路径文件,请使用 mysql_config_editor 实用程序。请参阅 第 6.6.7 节,“mysql_config_editor — MySQL 配置实用程序”。有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
-
命令行格式 --no-login-paths
跳过从登录路径文件读取选项。
有关相关信息,请参阅
--login-path
。有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
--password[=
,password
]-p[
password
]命令行格式 --password[=password]
类型 字符串 用于连接到服务器的 MySQL 帐户的密码。密码值是可选的。如果未给出,mysqldump 会提示输入一个。如果给出,则
--password=
或-p
与其后的密码之间必须没有空格。如果没有指定密码选项,则默认情况下不发送密码。在命令行上指定密码应该被认为是不安全的。为避免在命令行上提供密码,请使用选项文件。请参阅 第 8.1.2.1 节,“最终用户密码安全指南”。
要明确指定没有密码并且 mysqldump 不应提示输入密码,请使用
--skip-password
选项。用于连接到服务器的 MySQL 帐户的多因素身份验证因子 1 的密码。密码值是可选的。如果未给出,mysqldump 会提示输入一个。如果给出,则
--password1=
与其后的密码之间必须没有空格。如果没有指定密码选项,则默认情况下不发送密码。在命令行上指定密码应该被认为是不安全的。为避免在命令行上提供密码,请使用选项文件。请参阅 第 8.1.2.1 节,“最终用户密码安全指南”。
要明确指定没有密码并且 mysqldump 不应提示输入密码,请使用
--skip-password1
选项。--password1
和--password
是同义词,--skip-password1
和--skip-password
也是如此。用于连接到服务器的 MySQL 帐户的多因素身份验证因子 2 的密码。此选项的语义类似于
--password1
的语义;有关详细信息,请参阅该选项的说明。用于连接到服务器的 MySQL 帐户的多因素身份验证因子 3 的密码。此选项的语义类似于
--password1
的语义;有关详细信息,请参阅该选项的说明。--pipe
,-W
命令行格式 --pipe
类型 字符串 在 Windows 上,使用命名管道连接到服务器。仅当服务器在启动时启用了
named_pipe
系统变量以支持命名管道连接时,此选项才适用。此外,进行连接的用户必须是named_pipe_full_access_group
系统变量指定的 Windows 组的成员。--plugin-authentication-kerberos-client-mode=
value
命令行格式 --plugin-authentication-kerberos-client-mode
类型 字符串 默认值 SSPI
有效值 GSSAPI
在 Windows 上,
authentication_kerberos_client
身份验证插件支持此插件选项。它提供了客户端用户可以在运行时设置的两个可能的值:SSPI
和GSSAPI
。客户端插件选项的默认值使用安全支持提供程序接口 (SSPI),它能够从 Windows 内存缓存中获取凭据。或者,客户端用户可以通过 Windows 上的 MIT Kerberos 库选择支持通用安全服务应用程序编程接口 (GSSAPI) 的模式。GSSAPI 能够获取以前使用 kinit 命令生成的缓存凭据。
有关更多信息,请参阅 GSSAPI 模式下 Windows 客户端的命令。
-
命令行格式 --plugin-dir=dir_name
类型 目录名称 要在其中查找插件的目录。如果使用
--default-auth
选项指定身份验证插件但 mysqldump 找不到它,请指定此选项。请参阅 第 8.2.17 节,“可插拔身份验证”。 --port=
,port_num
-P
port_num
命令行格式 --port=port_num
类型 数字 默认值 3306
对于 TCP/IP 连接,要使用的端口号。
--protocol={TCP|SOCKET|PIPE|MEMORY}
命令行格式 --protocol=type
类型 字符串 默认值 [见正文]
有效值 TCP
SOCKET
PIPE
MEMORY
用于连接到服务器的传输协议。当其他连接参数通常导致使用您不想要的协议以外的协议时,它很有用。有关允许值的详细信息,请参阅 第 6.2.7 节,“连接传输协议”。
--server-public-key-path=
file_name
命令行格式 --server-public-key-path=file_name
类型 文件名 PEM 格式的文件的路径名,其中包含服务器对基于 RSA 密钥对的密码交换所需的公钥的客户端副本。此选项适用于使用
sha256_password
或caching_sha2_password
身份验证插件进行身份验证的客户端。对于未经这些插件身份验证的帐户,将忽略此选项。如果未使用基于 RSA 的密码交换,例如当客户端使用安全连接连接到服务器时,也会忽略此选项。如果给出了
--server-public-key-path=
并指定了有效的公钥文件,则它优先于file_name
--get-server-public-key
。对于
sha256_password
,仅当使用 OpenSSL 构建 MySQL 时,此选项才适用。有关
sha256_password
和caching_sha2_password
插件的信息,请参阅 第 8.4.1.2 节,“SHA-256 可插拔身份验证” 和 第 8.4.1.1 节,“缓存 SHA-2 可插拔身份验证”。--socket=
,路径
-S
路径
命令行格式 --socket={文件名|管道名}
类型 字符串 对于与
localhost
的连接,要使用的 Unix 套接字文件,或者在 Windows 上,要使用的命名管道的名称。在 Windows 上,仅当使用
named_pipe
系统变量启用服务器以支持命名管道连接时,此选项才适用。此外,进行连接的用户必须是named_pipe_full_access_group
系统变量指定的 Windows 组的成员。以
--ssl
开头的选项指定是否使用加密连接到服务器,并指示在何处找到 SSL 密钥和证书。请参阅 加密连接的命令选项。--ssl-fips-mode={OFF|ON|STRICT}
命令行格式 --ssl-fips-mode={OFF|ON|STRICT}
已弃用 是 类型 枚举 默认值 OFF
有效值 OFF
ON
STRICT
控制是否在客户端启用 FIPS 模式。
--ssl-fips-mode
选项与其他--ssl-
选项的不同之处在于,它不是用于建立加密连接,而是用于影响允许哪些加密操作。请参阅 第 8.8 节,“FIPS 支持”。xxx
允许使用以下
--ssl-fips-mode
值OFF
:禁用 FIPS 模式。ON
:启用 FIPS 模式。STRICT
:启用 “严格” FIPS 模式。
注意如果 OpenSSL FIPS 对象模块不可用,则
--ssl-fips-mode
唯一允许的值为OFF
。在这种情况下,将--ssl-fips-mode
设置为ON
或STRICT
会导致客户端在启动时产生警告并以非 FIPS 模式运行。此选项已弃用。预计它将在未来版本的 MySQL 中删除。
-
命令行格式 --tls-ciphersuites=密码套件列表
类型 字符串 使用 TLSv1.3 的加密连接允许的密码套件。该值是一个或多个以冒号分隔的密码套件名称的列表。可以为此选项命名的密码套件取决于用于编译 MySQL 的 SSL 库。有关详细信息,请参阅 第 8.3.2 节,“加密连接 TLS 协议和密码”。
-
命令行格式 --tls-sni-servername=服务器名称
类型 字符串 指定后,将使用
mysql_options()
的MYSQL_OPT_TLS_SNI_SERVERNAME
选项将名称传递给libmysqlclient
C API 库。服务器名称不区分大小写。要显示客户端为当前会话指定的服务器名称(如果有),请检查Tls_sni_server_name
状态变量。服务器名称指示 (SNI) 是 TLS 协议的扩展(必须使用 TLS 扩展编译 OpenSSL 才能使此选项起作用)。MySQL 对 SNI 的实现仅代表客户端。
-
命令行格式 --tls-version=协议列表
类型 字符串 默认值 TLSv1,TLSv1.1,TLSv1.2,TLSv1.3
(OpenSSL 1.1.1 或更高版本)TLSv1,TLSv1.1,TLSv1.2
(否则)加密连接允许的 TLS 协议。该值是一个或多个以逗号分隔的协议名称的列表。可以为此选项命名的协议取决于用于编译 MySQL 的 SSL 库。有关详细信息,请参阅 第 8.3.2 节,“加密连接 TLS 协议和密码”。
--user=
,用户名
-u
用户名
命令行格式 --user=用户名
类型 字符串 用于连接到服务器的 MySQL 帐户的用户名。
如果您正在使用
Rewriter
插件,则应授予该用户SKIP_QUERY_REWRITE
权限。-
命令行格式 --zstd-compression-level=#
类型 整数 用于连接到使用
zstd
压缩算法的服务器的压缩级别。允许的级别为 1 到 22,值越大表示压缩级别越高。默认的zstd
压缩级别为 3。压缩级别设置对不使用zstd
压缩的连接没有影响。有关更多信息,请参阅 第 6.2.8 节,“连接压缩控制”。
选项文件选项
这些选项用于控制要读取哪些选项文件。
-
命令行格式 --defaults-extra-file=文件名
类型 文件名 在全局选项文件之后但(在 Unix 上)在用户选项文件之前读取此选项文件。如果该文件不存在或不可访问,则会发生错误。如果
文件名
不是绝对路径名,则相对于当前目录解释它。有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
-
命令行格式 --defaults-file=文件名
类型 文件名 仅使用给定的选项文件。如果该文件不存在或不可访问,则会发生错误。如果
文件名
不是绝对路径名,则相对于当前目录解释它。例外:即使使用
--defaults-file
,客户端程序也会读取.mylogin.cnf
。有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
-
命令行格式 --defaults-group-suffix=字符串
类型 字符串 不仅读取通常的选项组,还读取具有通常名称和后缀
字符串
的组。例如,mysqldump 通常读取[client]
和[mysqldump]
组。如果将此选项指定为--defaults-group-suffix=_other
,则 mysqldump 还会读取[client_other]
和[mysqldump_other]
组。有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
-
命令行格式 --no-defaults
不读取任何选项文件。如果由于从选项文件中读取未知选项而导致程序启动失败,则可以使用
--no-defaults
来防止读取它们。例外情况是,如果
.mylogin.cnf
文件存在,则在所有情况下都会读取它。这允许以比在命令行上更安全的方式指定密码,即使在使用--no-defaults
时也是如此。要创建.mylogin.cnf
,请使用 mysql_config_editor 实用程序。请参阅 第 6.6.7 节,“mysql_config_editor — MySQL 配置实用程序”。有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
-
命令行格式 --print-defaults
打印程序名称及其从选项文件中获取的所有选项。
有关此选项文件选项和其他选项文件选项的其他信息,请参阅 第 6.2.2.3 节,“影响选项文件处理的命令行选项”。
DDL 选项
mysqldump 的使用场景包括设置全新的 MySQL 实例(包括数据库表),以及使用现有数据库和表替换现有实例中的数据。以下选项允许您通过在转储文件中编码各种 DDL 语句来指定在恢复转储时要删除和设置的内容。
-
命令行格式 --add-drop-database
在每个
CREATE DATABASE
语句之前写入DROP DATABASE
语句。此选项通常与--all-databases
或--databases
选项一起使用,因为除非指定了其中一个选项,否则不会写入CREATE DATABASE
语句。注意在 MySQL 9.0 中,
mysql
架构被视为系统架构,最终用户无法删除它。如果将--add-drop-database
与--all-databases
或--databases
(其中要转储的架构列表包括mysql
)一起使用,则转储文件包含DROP DATABASE `mysql`
语句,该语句在重新加载转储文件时会导致错误。相反,要使用
--add-drop-database
,请将--databases
与要转储的架构列表一起使用,其中该列表不包括mysql
。 -
命令行格式 --add-drop-table
在每个
CREATE TABLE
语句之前写入DROP TABLE
语句。 -
命令行格式 --add-drop-trigger
在每个
CREATE TRIGGER
语句之前写入DROP TRIGGER
语句。 -
命令行格式 --all-tablespaces
将创建
NDB
表所使用的任何表空间所需的所有 SQL 语句添加到表转储中。 此信息不会包含在 mysqldump 的输出中。 此选项当前仅与 NDB 集群表相关。 --no-create-db
,-n
命令行格式 --no-create-db
如果给定了
--databases
或--all-databases
选项,则禁止输出中包含的CREATE DATABASE
语句。--no-create-info
,-t
命令行格式 --no-create-info
不要编写创建每个转储表的
CREATE TABLE
语句。注意此选项不会 从 mysqldump 输出中排除创建日志文件组或表空间的语句;但是,您可以使用
--no-tablespaces
选项来实现此目的。--no-tablespaces
,-y
命令行格式 --no-tablespaces
此选项禁止 mysqldump 的输出中的所有
CREATE LOGFILE GROUP
和CREATE TABLESPACE
语句。-
命令行格式 --replace
调试选项
以下选项打印调试信息,在转储文件中编码调试信息,或让转储操作继续进行,而不管潜在的问题。
-
命令行格式 --allow-keywords
允许创建关键字的列名。 这是通过在每个列名前加上表名来实现的。
--comments
,-i
命令行格式 --comments
在转储文件中写入其他信息,例如程序版本、服务器版本和主机。 默认情况下启用此选项。 要禁止显示此附加信息,请使用
--skip-comments
。--debug[=
,debug_options
]-# [
debug_options
]命令行格式 --debug[=debug_options]
类型 字符串 默认值 d:t:o,/tmp/mysqldump.trace
编写调试日志。 典型的
debug_options
字符串是d:t:o,
。 默认值为file_name
d:t:o,/tmp/mysqldump.trace
。仅当使用
WITH_DEBUG
构建 MySQL 时,此选项才可用。 Oracle 提供的 MySQL 发行版二进制文件未使用此选项构建。-
命令行格式 --debug-check
类型 布尔值 默认值 FALSE
程序退出时打印一些调试信息。
仅当使用
WITH_DEBUG
构建 MySQL 时,此选项才可用。 Oracle 提供的 MySQL 发行版二进制文件未使用此选项构建。 -
命令行格式 --debug-info
类型 布尔值 默认值 FALSE
程序退出时打印调试信息以及内存和 CPU 使用情况统计信息。
仅当使用
WITH_DEBUG
构建 MySQL 时,此选项才可用。 Oracle 提供的 MySQL 发行版二进制文件未使用此选项构建。 -
命令行格式 --dump-date
类型 布尔值 默认值 TRUE
如果给定了
--comments
选项,则 mysqldump 会在转储结束时生成如下形式的注释-- Dump completed on DATE
但是,日期会导致在不同时间获取的转储文件看起来不同,即使数据在其他方面相同。
--dump-date
和--skip-dump-date
控制是否将日期添加到注释中。 默认值为--dump-date
(在注释中包含日期)。--skip-dump-date
禁止打印日期。 --force
,-f
命令行格式 --force
忽略所有错误;即使在表转储期间发生 SQL 错误,也要继续。
此选项的一种用途是使 mysqldump 即使在遇到因定义引用已删除的表而变得无效的视图时也能继续执行。 如果没有
--force
,mysqldump 会退出并显示错误消息。 使用--force
,mysqldump 会打印错误消息,但它也会将包含视图定义的 SQL 注释写入转储输出并继续执行。如果还给出了
--ignore-error
选项来忽略特定错误,则--force
优先。-
命令行格式 --log-error=file_name
类型 文件名 通过将警告和错误附加到命名文件来记录它们。 默认情况下不进行日志记录。
-
命令行格式 --skip-comments
请参阅
--comments
选项的说明。 --verbose
,-v
命令行格式 --verbose
详细模式。 打印有关程序功能的更多信息。
帮助选项
以下选项显示有关 mysqldump 命令本身的信息。
国际化选项
以下选项更改 mysqldump 命令如何使用国家语言设置表示字符数据。
-
命令行格式 --character-sets-dir=dir_name
类型 目录名称 安装字符集的目录。 请参阅 第 12.15 节“字符集配置”。
--default-character-set=
charset_name
命令行格式 --default-character-set=charset_name
类型 字符串 默认值 utf8
使用
charset_name
作为默认字符集。 请参阅 第 12.15 节“字符集配置”。 如果未指定字符集,则 mysqldump 使用utf8mb4
。--no-set-names
,-N
命令行格式 --no-set-names
已弃用 是 关闭
--set-charset
设置,与指定--skip-set-charset
相同。-
命令行格式 --set-charset
被禁用 skip-set-charset
写入
SET NAMES
到输出。 默认情况下启用此选项。 要禁止显示default_character_set
SET NAMES
语句,请使用--skip-set-charset
。
复制选项
mysqldump 命令通常用于在复制配置中的副本服务器上创建一个空实例,或创建一个包含数据的实例。 以下选项适用于在复制源服务器和副本上转储和恢复数据。
-
命令行格式 --apply-replica-statements
类型 布尔值 默认值 FALSE
对于使用
--dump-replica
选项生成的副本转储,此选项在带有二进制日志坐标的语句之前添加STOP REPLICA
语句,并在输出的末尾添加START REPLICA
语句。 -
命令行格式 --apply-slave-statements
已弃用 是 类型 布尔值 默认值 FALSE
这是
--apply-replica-statements
的已弃用别名。 -
命令行格式 --delete-source-logs
在复制源服务器上,通过在执行转储操作后向服务器发送
PURGE BINARY LOGS
语句来删除二进制日志。 这些选项需要RELOAD
权限以及足以执行该语句的权限。 此选项会自动启用--source-data
。 -
命令行格式 --delete-master-logs
已弃用 是 这是
--delete-source-logs
的已弃用别名。 -
命令行格式 --dump-replica[=value]
类型 数字 默认值 1
有效值 1
2
此选项类似于
--source-data
,不同之处在于它用于转储副本服务器以生成可用于将另一台服务器设置为与转储服务器具有相同来源的副本的转储文件。该选项使转储输出包含CHANGE REPLICATION SOURCE TO
语句,该语句指示转储副本来源的二进制日志坐标(文件名和位置)。CHANGE REPLICATION SOURCE TO
语句从SHOW REPLICA STATUS
输出中读取Relay_Master_Log_File
和Exec_Master_Log_Pos
的值,并分别将它们用于SOURCE_LOG_FILE
和SOURCE_LOG_POS
。这些是副本开始复制的复制源服务器坐标。注意已执行的来自中继日志的事务序列中的不一致可能会导致使用错误的位置。有关更多信息,请参阅第 19.5.1.35 节“复制和事务不一致”。
--dump-replica
会导致使用来自源的坐标,而不是使用转储服务器的坐标,就像--source-data
选项所做的那样。此外,指定此选项会覆盖--source-data
选项。警告如果要应用转储文件的服务器使用
gtid_mode=ON
和SOURCE_AUTO_POSITION=1
,则不应使用--dump-replica
。选项值的处理方式与
--source-data
相同。设置为空值或 1 会导致将CHANGE REPLICATION SOURCE TO
语句写入转储。设置 2 会导致将语句写入,但用 SQL 注释括起来。它在启用或禁用其他选项以及如何处理锁定方面与--source-data
具有相同的效果。--dump-replica
会导致mysqldump在转储之前停止复制 SQL 线程,并在之后重新启动它。--dump-replica
向服务器发送SHOW REPLICA STATUS
语句以获取信息,因此它们需要足够的权限来执行该语句。--apply-replica-statements
和--include-source-host-port
选项可以与--dump-replica
一起使用。 -
命令行格式 --dump-slave[=值]
已弃用 是 类型 数字 默认值 1
有效值 1
2
这是
--dump-replica
的已弃用别名。 -
命令行格式 --include-source-host-port
类型 布尔值 默认值 FALSE
将副本源的主机名和 TCP/IP 端口号的
SOURCE_HOST
和SOURCE_PORT
选项添加到使用--dump-replica
选项生成的副本转储中的CHANGE REPLICATION SOURCE TO
语句。 -
命令行格式 --include-master-host-port
已弃用 是 类型 布尔值 默认值 FALSE
这是
--include-source-host-port
的已弃用别名。 -
命令行格式 --master-data[=值]
已弃用 是 类型 数字 默认值 1
有效值 1
2
这是
--source-data
的已弃用别名。 -
命令行格式 --output-as-version=值
类型 枚举 默认值 SERVER
有效值 BEFORE_8_0_23
BEFORE_8_2_0
确定用于与副本和事件相关的语句的术语级别,从而可以创建与不接受较新术语的旧版本 MySQL 兼容的转储文件。此选项可以采用以下任何值,其效果如下所述
SERVER
:读取服务器版本并使用与该版本兼容的最新版本的语句。这是默认值。BEFORE_8_0_23
:使用已弃用术语(例如“从属”和“主控”)的复制 SQL 语句将写入输出,以代替使用“副本”和“源”的语句,如 8.0.23 之前的 MySQL 版本。此选项还会复制
BEFORE_8_2_0
对SHOW CREATE EVENT
输出的影响。BEFORE_8_2_0
:此选项会导致SHOW CREATE EVENT
反映事件在 8.2.0 版之前的 MySQL 服务器中是如何创建的,显示DISABLE ON SLAVE
而不是DISABLE ON REPLICA
。
此选项会影响
--events
、--dump-replica
、--source-data
、--apply-replica-statements
和--include-source-host-port
的输出。 -
命令行格式 --source-data[=值]
类型 数字 默认值 1
有效值 1
2
用于转储复制源服务器以生成可用于将另一台服务器设置为源副本的转储文件。这些选项会导致转储输出包含
CHANGE REPLICATION SOURCE TO
语句,该语句指示转储服务器的二进制日志坐标(文件名和位置)。这些是您将转储文件加载到副本后副本应开始复制的复制源服务器坐标。如果选项值为 2,则
CHANGE REPLICATION SOURCE TO
语句将作为 SQL 注释写入,因此仅供参考;重新加载转储文件时它不起作用。如果选项值为 1,则该语句不会作为注释写入,并在重新加载转储文件时生效。如果未指定选项值,则默认值为 1。--source-data
向服务器发送SHOW BINARY LOG STATUS
语句以获取信息,因此它们需要足够的权限来执行该语句。此选项还需要RELOAD
权限,并且必须启用二进制日志。--source-data
会自动关闭--lock-tables
。它们还会打开--lock-all-tables
,除非还指定了--single-transaction
,在这种情况下,仅在转储开始时获取全局读锁一小段时间(请参阅--single-transaction
的描述)。在所有情况下,日志上的任何操作都会在转储的确切时间发生。也可以通过使用
--dump-replica
选项转储源的现有副本,来设置副本,该选项会覆盖--source-data
,从而导致它被忽略。 -
命令行格式 --set-gtid-purged=值
类型 枚举 默认值 AUTO
有效值 OFF
ON
AUTO
此选项适用于使用基于 GTID 的复制的服务器 (
gtid_mode=ON
)。它控制在转储输出中包含SET @@GLOBAL.gtid_purged
语句,该语句更新重新加载转储文件的服务器上的gtid_purged
的值,以添加源服务器的gtid_executed
系统变量中的 GTID 集。gtid_purged
保存已在服务器上应用的所有事务的 GTID,但服务器上的任何二进制日志文件中都不存在这些 GTID。mysqldump因此添加了在源服务器上执行的事务的 GTID,以便目标服务器将这些事务记录为已应用,尽管它的二进制日志中没有这些事务。--set-gtid-purged
还控制包含SET @@SESSION.sql_log_bin=0
语句,该语句在重新加载转储文件时禁用二进制日志记录。此语句可防止在执行转储文件中的事务时生成新 GTID 并将其分配给这些事务,以便使用事务的原始 GTID。如果您没有设置
--set-gtid-purged
选项,则默认情况下,如果在要备份的服务器上启用了 GTID,并且gtid_executed
系统变量的全局值中的 GTID 集不为空,则转储输出中会包含SET @@GLOBAL.gtid_purged
语句。如果在服务器上启用了 GTID,则还会包含SET @@SESSION.sql_log_bin=0
语句。您可以将
gtid_purged
的值替换为指定的 GTID 集,也可以在语句中添加加号 (+) 以将指定的 GTID 集追加到gtid_purged
已持有的 GTID 集。mysqldump记录的SET @@GLOBAL.gtid_purged
语句在特定于版本的注释中包含加号 (+
),以便 MySQL 将转储文件中的 GTID 集添加到现有的gtid_purged
值。值得注意的是,mysqldump 为
SET @@GLOBAL.gtid_purged
语句包含的值包括服务器上gtid_executed
集中所有事务的 GTID,即使是那些更改了数据库中被抑制部分或服务器上未包含在部分转储中的其他数据库的事务。 这意味着在已更新转储文件所在服务器上的gtid_purged
值后,存在的 GTID 与目标服务器上的任何数据无关。 如果您没有在目标服务器上重放任何其他转储文件,则无关的 GTID 不会对服务器的未来操作造成任何问题,但它们会使比较或协调复制拓扑中不同服务器上的 GTID 集变得更加困难。 如果您确实在目标服务器上重放了包含相同 GTID 的其他转储文件(例如,来自同一来源服务器的另一个部分转储),则第二个转储文件中的任何SET @@GLOBAL.gtid_purged
语句都将失败。 在这种情况下,请在重放转储文件之前手动删除该语句,或输出不包含该语句的转储文件。如果
SET @@GLOBAL.gtid_purged
语句在您的目标服务器上没有预期的结果,您可以从输出中排除该语句,或者将其包含在内但将其注释掉,这样它就不会自动执行。 您还可以包含该语句,但在转储文件中手动编辑它以达到预期的结果。--set-gtid-purged
选项的可能值如下-
AUTO
默认值。 如果您要备份的服务器上启用了 GTID 并且
gtid_executed
不为空,则会将SET @@GLOBAL.gtid_purged
添加到输出中,其中包含来自gtid_executed
的 GTID 集。 如果启用了 GTID,则会将SET @@SESSION.sql_log_bin=0
添加到输出中。 如果服务器上未启用 GTID,则不会将这些语句添加到输出中。-
OFF
SET @@GLOBAL.gtid_purged
不会添加到输出中,并且SET @@SESSION.sql_log_bin=0
不会添加到输出中。 对于未启用 GTID 的服务器,请使用此选项或AUTO
。 仅当您确定目标服务器上的gtid_purged
中已存在所需的 GTID 集并且不应更改时,才对启用了 GTID 的服务器使用此选项,或者如果您打算手动识别并添加任何缺少的 GTID。-
ON
如果您要备份的服务器上启用了 GTID,则会将
SET @@GLOBAL.gtid_purged
添加到输出中(除非gtid_executed
为空),并且会将SET @@SESSION.sql_log_bin=0
添加到输出中。 如果您设置了此选项但服务器上未启用 GTID,则会发生错误。 对于启用了 GTID 的服务器,请使用此选项或AUTO
,除非您确定目标服务器上不需要gtid_executed
中的 GTID。-
COMMENTED(已注释)
如果您要备份的服务器上启用了 GTID,则会将
SET @@GLOBAL.gtid_purged
添加到输出中(除非gtid_executed
为空),但它会被注释掉。 这意味着gtid_executed
的值在输出中可用,但在重新加载转储文件时不会自动执行任何操作。SET @@SESSION.sql_log_bin=0
会添加到输出中,并且不会被注释掉。 使用COMMENTED
,您可以手动或通过自动化控制gtid_executed
集的使用。 例如,如果您要将数据迁移到已经具有不同活动数据库的另一台服务器,则您可能更愿意这样做。
-
格式选项
以下选项指定如何表示整个转储文件或转储文件中某些类型的数据。 它们还控制是否将某些可选信息写入转储文件。
-
命令行格式 --compact
生成更紧凑的输出。 此选项启用
--skip-add-drop-table
、--skip-add-locks
、--skip-comments
、--skip-disable-keys
和--skip-set-charset
选项。 -
命令行格式 --compatible=名称[,名称,...]
类型 字符串 默认值 ''
有效值 ansi
mysql323
mysql40
postgresql
oracle
mssql
db2
maxdb
no_key_options
no_table_options
no_key_options
生成与其他数据库系统或旧版 MySQL 服务器更兼容的输出。 此选项唯一允许的值是
ansi
,它与设置服务器 SQL 模式的相应选项具有相同的含义。 请参阅 第 7.1.11 节“服务器 SQL 模式”。 -
命令行格式 --complete-insert
使用包含列名的完整
INSERT
语句。 -
命令行格式 --create-options
在
CREATE TABLE
语句中包含所有 MySQL 特定的表选项。 --fields-terminated-by=...
、--fields-enclosed-by=...
、--fields-optionally-enclosed-by=...
、--fields-escaped-by=...
命令行格式 --fields-terminated-by=字符串
类型 字符串 命令行格式 --fields-enclosed-by=字符串
类型 字符串 命令行格式 --fields-optionally-enclosed-by=字符串
类型 字符串 命令行格式 --fields-escaped-by
类型 字符串 这些选项与
--tab
选项一起使用,并且与LOAD DATA
的相应FIELDS
子句具有相同的含义。 请参阅 第 15.2.9 节“LOAD DATA 语句”。-
命令行格式 --hex-blob
使用十六进制表示法转储二进制列(例如,
'abc'
变为0x616263
)。 受影响的数据类型是BINARY
、VARBINARY
、BLOB
类型、BIT
、所有空间数据类型以及与binary
字符集一起使用时的其他非二进制数据类型。使用
--tab
时,将忽略--hex-blob
选项。 -
命令行格式 --lines-terminated-by=字符串
类型 字符串 此选项与
--tab
选项一起使用,并且与LOAD DATA
的相应LINES
子句具有相同的含义。 请参阅 第 15.2.9 节“LOAD DATA 语句”。 -
命令行格式 --quote-names
被禁用 skip-quote-names
在
`
字符内引用标识符(例如数据库、表和列名)。 如果启用了ANSI_QUOTES
SQL 模式,则会在"
字符内引用标识符。 此选项默认启用。 可以使用--skip-quote-names
禁用它,但此选项应在任何可能启用--quote-names
的选项(例如--compatible
)之后给出。 --result-file=
、文件名
-r
文件名
命令行格式 --result-file=文件名
类型 文件名 将输出直接定向到指定的文件。 将创建结果文件并覆盖其先前的内容,即使在生成转储时发生错误也是如此。
此选项应在 Windows 上使用,以防止换行符
\n
字符转换为\r\n
回车符/换行符序列。--show-create-skip-secondary-engine=
值
命令行格式 --show-create-skip-secondary-engine
从
CREATE TABLE
语句中排除SECONDARY ENGINE
子句。 它通过在转储操作期间启用show_create_table_skip_secondary_engine
系统变量来实现这一点。 或者,您可以在使用 mysqldump 之前启用show_create_table_skip_secondary_engine
系统变量。--tab=
、目录名
-T
目录名
命令行格式 --tab=目录名
类型 目录名称 生成制表符分隔的文本格式数据文件。 对于每个转储的表,mysqldump 会创建一个
文件,其中包含创建该表的表名
.sqlCREATE TABLE
语句,并且服务器会写入一个
文件,其中包含其数据。 选项值是要写入文件的目录。表名
.txt注意仅当在与 mysqld 服务器相同的机器上运行 mysqldump 时,才应使用此选项。 因为服务器会在您指定的目录中创建
*.txt
文件,所以该目录必须可由服务器写入,并且您使用的 MySQL 帐户必须具有FILE
权限。 因为 mysqldump 在同一目录中创建*.sql
,所以它必须可由您的系统登录帐户写入。默认情况下,
.txt
数据文件使用列值之间的制表符和每行末尾的换行符进行格式化。 可以使用--fields-
和xxx
--lines-terminated-by
选项显式指定格式。列值将转换为
--default-character-set
选项指定的字符集。-
命令行格式 --tz-utc
被禁用 skip-tz-utc
此选项允许在不同时区的服务器之间转储和重新加载
TIMESTAMP
列。 mysqldump 将其连接时区设置为 UTC,并将SET TIME_ZONE='+00:00'
添加到转储文件。如果没有此选项,TIMESTAMP
列将在源服务器和目标服务器的本地时区中转储和重新加载,如果服务器位于不同的时区,这可能会导致值发生更改。--tz-utc
还可以防止因夏令时而发生更改。默认情况下启用--tz-utc
。要禁用它,请使用--skip-tz-utc
。 --xml
,-X
命令行格式 --xml
将转储输出写入格式良好的 XML。
NULL
、'NULL'
和空值:对于名为column_name
的列,NULL
值、空字符串和字符串值'NULL'
在此选项生成的输出中彼此区分如下。值 XML 表示 NULL
(未知值)<field name="
column_name
" xsi:nil="true" />''
(空字符串)<field name="
column_name
"></field>'NULL'
(字符串值)<field name="
column_name
">NULL</field>使用
--xml
选项运行时,mysql 客户端的输出也遵循前面的规则。(请参阅 第 6.5.1.1 节“mysql 客户端选项”。)mysqldump 的 XML 输出包含 XML 命名空间,如下所示
$> mysqldump --xml -u root world City <?xml version="1.0"?> <mysqldump xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <database name="world"> <table_structure name="City"> <field Field="ID" Type="int(11)" Null="NO" Key="PRI" Extra="auto_increment" /> <field Field="Name" Type="char(35)" Null="NO" Key="" Default="" Extra="" /> <field Field="CountryCode" Type="char(3)" Null="NO" Key="" Default="" Extra="" /> <field Field="District" Type="char(20)" Null="NO" Key="" Default="" Extra="" /> <field Field="Population" Type="int(11)" Null="NO" Key="" Default="0" Extra="" /> <key Table="City" Non_unique="0" Key_name="PRIMARY" Seq_in_index="1" Column_name="ID" Collation="A" Cardinality="4079" Null="" Index_type="BTREE" Comment="" /> <options Name="City" Engine="MyISAM" Version="10" Row_format="Fixed" Rows="4079" Avg_row_length="67" Data_length="273293" Max_data_length="18858823439613951" Index_length="43008" Data_free="0" Auto_increment="4080" Create_time="2007-03-31 01:47:01" Update_time="2007-03-31 01:47:02" Collation="latin1_swedish_ci" Create_options="" Comment="" /> </table_structure> <table_data name="City"> <row> <field name="ID">1</field> <field name="Name">Kabul</field> <field name="CountryCode">AFG</field> <field name="District">Kabol</field> <field name="Population">1780000</field> </row> ... <row> <field name="ID">4079</field> <field name="Name">Rafah</field> <field name="CountryCode">PSE</field> <field name="District">Rafah</field> <field name="Population">92020</field> </row> </table_data> </database> </mysqldump>
过滤选项
以下选项控制将哪些类型的架构对象写入转储文件:按类别,例如触发器或事件;按名称,例如选择要转储的数据库和表;甚至使用 WHERE
子句从表数据中过滤行。
--all-databases
,-A
命令行格式 --all-databases
转储所有数据库中的所有表。这与使用
--databases
选项并在命令行中命名所有数据库相同。注意有关该选项与
--all-databases
的不兼容性的信息,请参阅--add-drop-database
说明。在 MySQL 9.0 之前,mysqldump 的
--routines
和--events
选项在使用--all-databases
选项时不需要包含存储例程和事件:转储包含mysql
系统数据库,因此还包含存储例程和事件定义的mysql.proc
和mysql.event
表。从 MySQL 9.0 开始,不再使用mysql.event
和mysql.proc
表。相应对象的定义存储在数据字典表中,但这些表不会被转储。要将存储例程和事件包含在使用--all-databases
创建的转储中,请明确使用--routines
和--events
选项。--databases
,-B
命令行格式 --databases
转储多个数据库。通常,mysqldump 将命令行上的第一个名称参数视为数据库名称,将后面的名称视为表名。使用此选项,它会将所有名称参数视为数据库名称。在每个新数据库之前,输出中都包含
CREATE DATABASE
和USE
语句。此选项可用于转储
performance_schema
数据库,即使使用--all-databases
选项,该数据库通常也不会被转储。(同时使用--skip-lock-tables
选项。)注意有关该选项与
--databases
的不兼容性的信息,请参阅--add-drop-database
说明。--events
,-E
命令行格式 --events
在输出中包含已转储数据库的事件调度程序事件。此选项需要这些数据库的
EVENT
权限。使用
--events
生成的输出包含用于创建事件的CREATE EVENT
语句。--ignore-error=
error[,error]...
命令行格式 --ignore-error=error[,error]...
类型 字符串 忽略指定的错误。选项值是由逗号分隔的错误号列表,指定在 mysqldump 执行期间要忽略的错误。如果还给出了
--force
选项以忽略所有错误,则--force
优先。--ignore-table=
db_name.tbl_name
命令行格式 --ignore-table=db_name.tbl_name
类型 字符串 不要转储给定的表,该表必须使用数据库名和表名来指定。要忽略多个表,请多次使用此选项。此选项也可用于忽略视图。
-
命令行格式 --ignore-views
类型 布尔值 默认值 FALSE
在转储文件中跳过表视图。
-
命令行格式 --init-command=str
类型 字符串 连接到 MySQL 服务器后要执行的单个 SQL 语句。该定义会重置由它或
init-command-add
定义的现有语句。 -
命令行格式 --init-command-add=str
类型 字符串 添加一个额外的 SQL 语句,以便在连接或重新连接到 MySQL 服务器后执行。它可以在没有
--init-command
的情况下使用,但如果在它之前使用则无效,因为init-command
会重置要调用的命令列表。 --no-data
,-d
命令行格式 --no-data
不写入任何表行信息(也就是说,不转储表内容)。如果您只想转储表的
CREATE TABLE
语句(例如,通过加载转储文件创建表的空副本),这将非常有用。--routines
,-R
命令行格式 --routines
在输出中包含已转储数据库的存储例程(过程和函数)。此选项需要全局
SELECT
权限。使用
--routines
生成的输出包含用于创建例程的CREATE PROCEDURE
和CREATE FUNCTION
语句。--skip-generated-invisible-primary-key
命令行格式 --skip-generated-invisible-primary-key
类型 布尔值 默认值 FALSE
此选项会导致从输出中排除生成的不可见主键。有关更多信息,请参阅 第 15.1.20.11 节“生成的不可见主键”。
-
命令行格式 --tables
覆盖
--databases
或-B
选项。 mysqldump 将该选项后面的所有名称参数都视为表名。 -
命令行格式 --triggers
被禁用 skip-triggers
在输出中包含每个已转储表的触发器。默认情况下启用此选项;使用
--skip-triggers
禁用它。要能够转储表的触发器,您必须具有该表的
TRIGGER
权限。允许多个触发器。 mysqldump 按激活顺序转储触发器,以便在重新加载转储文件时,以相同的激活顺序创建触发器。但是,如果 mysqldump 转储文件包含一个表的多个触发器,这些触发器具有相同的触发器事件和操作时间,则在尝试将转储文件加载到不支持多个触发器的旧服务器时会发生错误。(有关解决方法,请参阅 降级说明;您可以将触发器转换为与旧服务器兼容。)
--where='
,where_condition
'-w '
where_condition
'命令行格式 --where='where_condition'
仅转储由给定
WHERE
条件选择的行。如果条件包含空格或命令解释器特有的其他字符,则条件周围的引号是必需的。示例
--where="user='jimf'" -w"userid>1" -w"userid<1"
性能选项
以下选项与还原操作的性能最相关。对于大型数据集,还原操作(处理转储文件中的 INSERT
语句)是最耗时的部分。当需要快速还原数据时,请提前计划和测试此阶段的性能。对于以小时为单位测量的还原时间,您可能更喜欢其他备份和还原解决方案,例如适用于仅 InnoDB
和混合使用数据库的 MySQL 企业备份。
性能还受 事务选项 的影响,主要针对转储操作。
-
命令行格式 --column-statistics
类型 布尔值 默认值 OFF
将
ANALYZE TABLE
语句添加到输出中,以便在重新加载转储文件时为转储的表生成直方图统计信息。默认情况下禁用此选项,因为为大型表生成直方图可能需要很长时间。 --disable-keys
,-K
命令行格式 --disable-keys
对于每个表,使用
/*!40000 ALTER TABLE
和tbl_name
DISABLE KEYS */;/*!40000 ALTER TABLE
语句将tbl_name
ENABLE KEYS */;INSERT
语句括起来。这会加快转储文件的加载速度,因为索引是在插入所有行之后创建的。此选项仅对MyISAM
表的非唯一索引有效。-
命令行格式 --extended-insert
被禁用 skip-extended-insert
使用包含多个
VALUES
列表的多行语法编写INSERT
语句。这将生成更小的转储文件,并在重新加载文件时加快插入速度。 -
命令行格式 --insert-ignore
编写
INSERT IGNORE
语句,而不是INSERT
语句。 -
命令行格式 --max-allowed-packet=value
类型 数字 默认值 25165824
客户端/服务器通信的缓冲区最大大小。默认值为 24MB,最大值为 1GB。
注意此选项的值特定于 mysqldump,不应与 MySQL 服务器的
max_allowed_packet
系统变量混淆;服务器值不能超过来自 mysqldump 的单个数据包,而不管 mysqldump 选项的任何设置如何,即使后者更大。 --mysqld-long-query-time=
value
命令行格式 --mysqld-long-query-time=value
类型 数字 默认值 服务器全局设置
设置
long_query_time
系统变量的会话值。如果要增加在将来自 mysqldump 的查询记录到慢查询日志文件之前允许的时间,请使用此选项。mysqldump 执行全表扫描,这意味着其查询通常会超过对常规查询有用的全局long_query_time
设置。默认的全局设置为 10 秒。您可以使用
--mysqld-long-query-time
指定从 0(表示来自 mysqldump 的每个查询都记录到慢查询日志中)到 31536000(以秒为单位的 365 天)的会话值。对于 mysqldump 的选项,您只能指定整秒。如果未指定此选项,则服务器的全局设置将应用于 mysqldump 的查询。-
命令行格式 --net-buffer-length=value
类型 数字 默认值 16384
客户端/服务器通信的缓冲区的初始大小。创建多行
INSERT
语句(如使用--extended-insert
或--opt
选项)时,mysqldump 创建的行长度最大为--net-buffer-length
字节。如果增加此变量,请确保 MySQL 服务器net_buffer_length
系统变量的值至少与此值一样大。 -
命令行格式 --network-timeout[={0|1}]
类型 布尔值 默认值 TRUE
通过将
--max-allowed-packet
设置为最大值并将网络读写超时设置为较大的值,可以转储大型表。默认情况下启用此选项。要禁用它,请使用--skip-network-timeout
。 -
命令行格式 --opt
被禁用 skip-opt
此选项默认启用,是
--add-drop-table
--add-locks
--create-options
--disable-keys
--extended-insert
--lock-tables
--quick
--set-charset
组合的简写形式。它提供了快速的转储操作,并生成可以快速重新加载到 MySQL 服务器中的转储文件。因为默认情况下启用
--opt
选项,所以您只需指定其反义词--skip-opt
即可关闭多个默认设置。有关选择性启用或禁用--opt
影响的选项子集的信息,请参阅mysqldump
选项组 的讨论。 --quick
,-q
命令行格式 --quick
被禁用 skip-quick
此选项对于转储大型表很有用。它强制 mysqldump 一次从服务器检索表中的一行,而不是检索整个行集并将其缓冲到内存中,然后再将其写出。
-
命令行格式 --skip-opt
请参阅
--opt
选项的说明。
事务选项
以下选项在转储操作的性能与导出数据的可靠性和一致性之间进行权衡。
-
命令行格式 --add-locks
使用
LOCK TABLES
和UNLOCK TABLES
语句将每个表转储括起来。这会在重新加载转储文件时加快插入速度。请参阅 第 10.2.5.1 节“优化 INSERT 语句”。 --flush-logs
,-F
命令行格式 --flush-logs
在开始转储之前刷新 MySQL 服务器日志文件。此选项需要
RELOAD
权限。如果将此选项与--all-databases
选项一起使用,则会 为每个转储的数据库 刷新日志。但使用--lock-all-tables
、--source-data
或--single-transaction
时除外。在这些情况下,日志只刷新一次,对应于FLUSH TABLES WITH READ LOCK
锁定所有表的时刻。如果希望转储和日志刷新在完全相同的时刻发生,则应将--flush-logs
与--lock-all-tables
、--source-data
或--single-transaction
一起使用。-
命令行格式 --flush-privileges
在转储
mysql
数据库之后,将FLUSH PRIVILEGES
语句添加到转储输出中。每当转储包含mysql
数据库和任何其他依赖于mysql
数据库中的数据才能正确还原的数据库时,都应使用此选项。因为转储文件包含
FLUSH PRIVILEGES
语句,所以重新加载该文件需要足够的权限来执行该语句。 -
命令行格式 --lock-all-tables
锁定所有数据库中的所有表。这是通过在整个转储期间获取全局读锁来实现的。此选项会自动关闭
--single-transaction
和--lock-tables
。 --lock-tables
,-l
命令行格式 --lock-tables
对于每个转储的数据库,在转储之前锁定所有要转储的表。使用
READ LOCAL
锁定表,以便在MyISAM
表的情况下允许并发插入。对于InnoDB
等事务性表,--single-transaction
比--lock-tables
好得多,因为它根本不需要锁定表。因为
--lock-tables
会分别锁定每个数据库的表,所以此选项不能保证转储文件中的表在数据库之间逻辑上一致。不同数据库中的表可能会以完全不同的状态进行转储。某些选项(如
--opt
)会自动启用--lock-tables
。如果要覆盖此选项,请在选项列表的末尾使用--skip-lock-tables
。-
命令行格式 --no-autocommit
-
命令行格式 --order-by-primary
按照每个表的主键对其行进行排序转储,如果存在此类索引,则按照其第一个唯一索引进行排序。这在将
MyISAM
表转储到InnoDB
表中时非常有用,但会使转储操作花费更长时间。 --shared-memory-base-name=
name
命令行格式 --shared-memory-base-name=name
平台特定 Windows 在 Windows 上,用于使用共享内存连接到本地服务器的共享内存名称。默认值为
MYSQL
。共享内存名称区分大小写。仅当使用
shared_memory
系统变量启动服务器以支持共享内存连接时,此选项才适用。-
命令行格式 --single-transaction
此选项将事务隔离级别设置为
REPEATABLE READ
,并在转储数据之前向服务器发送START TRANSACTION
SQL 语句。它仅适用于事务性表(如InnoDB
),因为这样它会在发出START TRANSACTION
时转储数据库的一致状态,而不会阻塞任何应用程序。如果同时使用
gtid_mode=ON
和gtid_purged=ON|AUTO
,则使用--single-transaction
需要RELOAD
或FLUSH_TABLES
权限。使用此选项时,您应该记住,只有
InnoDB
表会以一致的状态进行转储。例如,使用此选项转储的任何MyISAM
或MEMORY
表仍然可能会更改状态。在
--single-transaction
转储过程中,为确保转储文件有效(表内容和二进制日志坐标正确),其他连接不应使用以下语句:ALTER TABLE
、CREATE TABLE
、DROP TABLE
、RENAME TABLE
、TRUNCATE TABLE
。一致性读取不与这些语句隔离,因此对要转储的表使用这些语句可能会导致 mysqldump 执行的SELECT
以检索表内容,从而获得错误的内容或失败。--single-transaction
选项和--lock-tables
选项是互斥的,因为LOCK TABLES
会导致隐式提交任何挂起的 transaksi。要转储大型表,请将
--single-transaction
选项与--quick
选项结合使用。
选项组
当您选择性地启用或禁用组选项的效果时,顺序很重要,因为选项的处理顺序是从第一个到最后一个。例如,--disable-keys
--lock-tables
--skip-opt
不会产生预期的效果;它与单独使用 --skip-opt
相同。
示例
备份整个数据库
mysqldump db_name > backup-file.sql
将转储文件加载回服务器
mysql db_name < backup-file.sql
重新加载转储文件的另一种方法
mysql -e "source /path-to-backup/backup-file.sql" db_name
mysqldump 对于通过将数据从一个 MySQL 服务器复制到另一个服务器来填充数据库也非常有用
mysqldump --opt db_name | mysql --host=remote_host -C db_name
您可以使用一个命令转储多个数据库
mysqldump --databases db_name1 [db_name2 ...] > my_databases.sql
要转储所有数据库,请使用 --all-databases
选项
mysqldump --all-databases > all_databases.sql
对于 InnoDB
表,mysqldump 提供了一种进行在线备份的方法
mysqldump --all-databases --source-data --single-transaction > all_databases.sql
此备份在转储开始时获取所有表的全局读锁(使用 FLUSH TABLES WITH READ LOCK
)。获取此锁后,将读取二进制日志坐标并释放锁。如果在发出 FLUSH
语句时正在运行长时间的更新语句,则 MySQL 服务器可能会停滞,直到这些语句完成。之后,转储将变为无锁状态,并且不会干扰对表的读写操作。如果 MySQL 服务器接收到的更新语句很短(就执行时间而言),则即使有许多更新,初始锁定时间也不应引起注意。
对于时间点恢复(也称为“前滚”,当您需要还原旧备份并重放自该备份以来发生的更改时),通常需要轮换二进制日志(请参阅 第 7.4.4 节“二进制日志”),或者至少知道转储对应的二进制日志坐标
mysqldump --all-databases --source-data=2 > all_databases.sql
或者
mysqldump --all-databases --flush-logs --source-data=2 > all_databases.sql
--source-data
选项可以与 --single-transaction
选项同时使用,这提供了一种便捷的方法来进行在线备份,如果表使用 InnoDB
存储引擎存储,则此备份适用于时间点恢复之前使用。
有关进行备份的更多信息,请参阅 第 9.2 节“数据库备份方法” 和 第 9.3 节“备份和恢复策略示例”。
要选择
--opt
的效果(除了一些功能之外),请对每个功能使用--skip
选项。要禁用扩展插入和内存缓冲,请使用--opt
--skip-extended-insert
--skip-quick
。(实际上,--skip-extended-insert
--skip-quick
就足够了,因为默认情况下--opt
处于启用状态。)要反转
--opt
的所有功能(除了禁用索引和表锁定之外),请使用--skip-opt
--disable-keys
--lock-tables
。
限制
默认情况下,mysqldump 不会转储 performance_schema
或 sys
模式。要转储其中任何一个,请在命令行上显式命名它们。您也可以使用 --databases
选项命名它们。对于 performance_schema
,还要使用 --skip-lock-tables
选项。
mysqldump 不会转储 INFORMATION_SCHEMA
模式。
mysqldump 不会转储 InnoDB
CREATE TABLESPACE
语句。
mysqldump 不会转储 NDB 集群 ndbinfo
信息数据库。
对于 mysql
数据库的转储,mysqldump 包括用于重新创建 general_log
和 slow_query_log
表的语句。不会转储日志表内容。
如果由于权限不足而在备份视图时遇到问题,请参阅 第 27.10 节“视图的限制” 以获取解决方法。