搜索
首页数据库mysql教程mysqldump使用惯用参数说明

mysqldump使用常用参数说明 我用来实现自动全备份的脚本(可以满足一般有前后版本兼容要求的导出导入操作,我的字符集是latin1): ?mysqldump.exe -umyusername -pmypass -h localhost -P 3306 --triggers=false --complete-insert? ??????? -q --extended-i

mysqldump使用常用参数说明

我用来实现自动全备份的脚本(可以满足一般有前后版本兼容要求的导出导入操作,我的字符集是latin1):

?mysqldump.exe -umyusername -pmypass -h localhost -P 3306 --triggers=false --complete-insert?
??????? -q --extended-insert=false? --default-character-set=latin1 --no-create-db=TRUE?
??????? --no-create-info=TRUE --add-drop-table=FALSE --replace=TRUE -B MY_DB >> "c:\123.sql"

?

如果库中有不断增加的海量数据,不建议参与日常的全备份,可以用--ignore-table忽略这些表(否则导出文件太大,导出过程太长)。

?

另附:mysqldump参数详细说明

Mysqldump参数大全(参数来源于mysql5.5.19源码)

?

参数

参数说明

--all-databases??,?-A

导出全部数据库。

mysqldump??-uroot?-p?--all-databases

--all-tablespaces??,?-Y

导出全部表空间。

mysqldump??-uroot?-p?--all-databases?--all-tablespaces

--no-tablespaces??,?-y

不导出任何表空间信息。

mysqldump??-uroot?-p?--all-databases?--no-tablespaces

--add-drop-database

每个数据库创建之前添加drop数据库语句。

mysqldump??-uroot?-p?--all-databases?--add-drop-database

--add-drop-table

每个数据表创建之前添加drop数据表语句。(默认为打开状态,使用--skip-add-drop-table取消选项)

mysqldump??-uroot?-p?--all-databases??(默认添加drop语句)

mysqldump??-uroot?-p?--all-databases?skip-add-drop-table??(取消drop语句)

--add-locks

在每个表导出之前增加LOCK?TABLES并且之后UNLOCK??TABLE(默认为打开状态,使用--skip-add-locks取消选项)

mysqldump??-uroot?-p?--all-databases??(默认添加LOCK语句)

mysqldump??-uroot?-p?--all-databases?skip-add-locks???(取消LOCK语句)

--allow-keywords

允许创建是关键词的列名字。这由表名前缀于每个列名做到。

mysqldump??-uroot?-p?--all-databases?--allow-keywords

--apply-slave-statements

'CHANGE?MASTER'前添加'STOP?SLAVE',并且在导出的最后添加'START?SLAVE'

mysqldump??-uroot?-p?--all-databases?--apply-slave-statements

--character-sets-dir

字符集文件的目录

mysqldump??-uroot?-p?--all-databases??--character-sets-dir=/usr/local/mysql/share/mysql/charsets

--comments

附加注释信息。默认为打开,可以用--skip-comments取消

mysqldump??-uroot?-p?--all-databases??(默认记录注释)

mysqldump??-uroot?-p?--all-databases?--skip-comments???(取消注释)

--compatible

导出的数据将和其它数据库或旧版本的MySQL?相兼容。值可以为ansimysql323mysql40postgresqloraclemssqldb2maxdbno_key_optionsno_tables_optionsno_field_options等,

要使用几个值,用逗号将它们隔开。它并不保证能完全兼容,而是尽量兼容。

mysqldump??-uroot?-p?--all-databases?--compatible=ansi

--compact

导出更少的输出信息(用于调试)。去掉注释和头尾等结构。可以使用选项:--skip-add-drop-table??--skip-add-locks?--skip-comments?--skip-disable-keys

mysqldump??-uroot?-p?--all-databases?--compact

--complete-insert,??-c

使用完整的insert语句(包含列名称)。这么做能提高插入效率,但是可能会受到max_allowed_packet参数的影响而导致插入失败。

mysqldump??-uroot?-p?--all-databases?--complete-insert

--compress,?-C

在客户端和服务器之间启用压缩传递所有信息

mysqldump??-uroot?-p?--all-databases?--compress

--create-options,??-a

CREATE?TABLE语句中包括所有MySQL特性选项。(默认为打开状态)

mysqldump??-uroot?-p?--all-databases

--databases,??-B

导出几个数据库。参数后面所有名字参量都被看作数据库名。

mysqldump??-uroot?-p?--databases?test?mysql

--debug

输出debug信息,用于调试。默认值为:d:t:o,/tmp/mysqldump.trace

mysqldump??-uroot?-p?--all-databases?--debug

mysqldump??-uroot?-p?--all-databases?--debug=?d:t:o,/tmp/debug.trace

--debug-check

检查内存和打开文件使用说明并退出。

mysqldump??-uroot?-p?--all-databases?--debug-check

--debug-info

输出调试信息并退出

mysqldump??-uroot?-p?--all-databases?--debug-info

--default-character-set

设置默认字符集,默认值为utf8

mysqldump??-uroot?-p?--all-databases?--default-character-set=latin1

--delayed-insert

采用延时插入方式(INSERT?DELAYED)导出数据

mysqldump??-uroot?-p?--all-databases?--delayed-insert

--delete-master-logs

master备份后删除日志.?这个参数将自动激活--master-data

mysqldump??-uroot?-p?--all-databases?--delete-master-logs

--disable-keys

对于每个表,用/*!40000?ALTER?TABLE?tbl_name?DISABLE?KEYS?*/;/*!40000?ALTER?TABLE?tbl_name?ENABLE?KEYS?*/;语句引用INSERT语句。这样可以更快地导入dump出来的文件,因为它是在插入所有行后创建索引的。该选项只适合MyISAM表,默认为打开状态。

mysqldump??-uroot?-p?--all-databases?

--dump-slave

该选项将导致主的binlog位置和文件名追加到导出数据的文件中。设置为1时,将会以CHANGE?MASTER命令输出到数据文件;设置为2时,在命令前增加说明信息。该选项将会打开--lock-all-tables,除非--single-transaction被指定。该选项会自动关闭--lock-tables选项。默认值为0

mysqldump??-uroot?-p?--all-databases?--dump-slave=1

mysqldump??-uroot?-p?--all-databases?--dump-slave=2

--events,?-E

导出事件。

mysqldump??-uroot?-p?--all-databases?--events

--extended-insert,??-e

使用具有多个VALUES列的INSERT语法。这样使导出文件更小,并加速导入时的速度。默认为打开状态,使用--skip-extended-insert取消选项。

mysqldump??-uroot?-p?--all-databases

mysqldump??-uroot?-p?--all-databases--skip-extended-insert???(取消选项)

--fields-terminated-by

导出文件中忽略给定字段。与--tab选项一起使用,不能用于--databases--all-databases选项

mysqldump??-uroot?-p?test?test?--tab=/home/mysql?--fields-terminated-by=#

--fields-enclosed-by

输出文件中的各个字段用给定字符包裹。与--tab选项一起使用,不能用于--databases--all-databases选项

mysqldump??-uroot?-p?test?test?--tab=/home/mysql?--fields-enclosed-by=#

--fields-optionally-enclosed-by

输出文件中的各个字段用给定字符选择性包裹。与--tab选项一起使用,不能用于--databases--all-databases选项

mysqldump??-uroot?-p?test?test?--tab=/home/mysql??--fields-enclosed-by=#?--fields-optionally-enclosed-by??=#

--fields-escaped-by

输出文件中的各个字段忽略给定字符。与--tab选项一起使用,不能用于--databases--all-databases选项

mysqldump??-uroot?-p?mysql?user?--tab=/home/mysql?--fields-escaped-by=#

--flush-logs

开始导出之前刷新日志。

请注意:假如一次导出多个数据库(使用选项--databases或者--all-databases),将会逐个数据库刷新日志。除使用--lock-all-tables或者--master-data外。在这种情况下,日志将会被刷新一次,相应的所以表同时被锁定。因此,如果打算同时导出和刷新日志应该使用--lock-all-tables?或者--master-data?--flush-logs

mysqldump??-uroot?-p?--all-databases?--flush-logs

--flush-privileges

在导出mysql数据库之后,发出一条FLUSH??PRIVILEGES?语句。为了正确恢复,该选项应该用于导出mysql数据库和依赖mysql数据库数据的任何时候。

mysqldump??-uroot?-p?--all-databases?--flush-privileges

--force

在导出过程中忽略出现的SQL错误。

mysqldump??-uroot?-p?--all-databases?--force

--help

显示帮助信息并退出。

mysqldump??--help

--hex-blob

使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用该选项。影响到的字段类型有BINARYVARBINARYBLOB

mysqldump??-uroot?-p?--all-databases?--hex-blob

--host,?-h

需要导出的主机信息

mysqldump??-uroot?-p?--host=localhost?--all-databases

--ignore-table

不导出指定表。指定忽略多个表时,需要重复多次,每次一个表。每个表必须同时指定数据库和表名。例如:--ignore-table=database.table1?--ignore-table=database.table2?……

mysqldump??-uroot?-p?--host=localhost?--all-databases?--ignore-table=mysql.user

--include-master-host-port

--dump-slave产生的'CHANGE??MASTER?TO..'语句中增加'MASTER_HOST=MASTER_PORT='??

mysqldump??-uroot?-p?--host=localhost?--all-databases?--include-master-host-port

--insert-ignore

在插入行时使用INSERT?IGNORE语句.

mysqldump??-uroot?-p?--host=localhost?--all-databases?--insert-ignore

--lines-terminated-by

输出文件的每行用给定字符串划分。与--tab选项一起使用,不能用于--databases--all-databases选项。

mysqldump??-uroot?-p?--host=localhost?test?test?--tab=/tmp/mysql??--lines-terminated-by=##

--lock-all-tables,??-x

提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭--single-transaction?--lock-tables?选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--lock-all-tables

--lock-tables,??-l

开始导出前,锁定所有表。用READ??LOCAL锁定表以允许MyISAM表并行插入。对于支持事务的表例如InnoDBBDB--single-transaction是一个更好的选择,因为它根本不需要锁定表。

请注意当导出多个数据库时,--lock-tables分别为每个数据库锁定表。因此,该选项不能保证导出文件中的表在数据库之间的逻辑一致性。不同数据库表的导出状态可以完全不同。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--lock-tables

--log-error

附加警告和错误信息到给定文件

mysqldump??-uroot?-p?--host=localhost?--all-databases??--log-error=/tmp/mysqldump_error_log.err

--master-data

该选项将binlog的位置和文件名追加到输出文件中。如果为1,将会输出CHANGE?MASTER?命令;如果为2,输出的CHANGE??MASTER命令前添加注释信息。该选项将打开--lock-all-tables?选项,除非--single-transaction也被指定(在这种情况下,全局读锁在开始导出时获得很短的时间;其他内容参考下面的--single-transaction选项)。该选项自动关闭--lock-tables选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--master-data=1;

mysqldump??-uroot?-p?--host=localhost?--all-databases?--master-data=2;

--max_allowed_packet

服务器发送和接受的最大包长度。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--max_allowed_packet=10240

--net_buffer_length

TCP/IPsocket连接的缓存大小。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--net_buffer_length=1024

--no-autocommit

使用autocommit/commit?语句包裹表。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--no-autocommit

--no-create-db,??-n

只导出数据,而不添加CREATE?DATABASE?语句。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--no-create-db

--no-create-info,??-t

只导出数据,而不添加CREATE?TABLE?语句。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--no-create-info

--no-data,?-d

不导出任何数据,只导出数据库表结构。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--no-data

--no-set-names,??-N

等同于--skip-set-charset

mysqldump??-uroot?-p?--host=localhost?--all-databases?--no-set-names

--opt

等同于--add-drop-table,??--add-locks,?--create-options,?--quick,?--extended-insert,?--lock-tables,??--set-charset,?--disable-keys?该选项默认开启,??可以用--skip-opt禁用.

mysqldump??-uroot?-p?--host=localhost?--all-databases?--opt

--order-by-primary

如果存在主键,或者第一个唯一键,对每个表的记录进行排序。在导出MyISAM表到InnoDB表时有效,但会使得导出工作花费很长时间。?

mysqldump??-uroot?-p?--host=localhost?--all-databases?--order-by-primary

--password,?-p

连接数据库密码

--pipe(windows系统可用)

使用命名管道连接mysql

mysqldump??-uroot?-p?--host=localhost?--all-databases?--pipe

--port,?-P

连接数据库端口号

--protocol

使用的连接协议,包括:tcp,?socket,?pipe,?memory.

mysqldump??-uroot?-p?--host=localhost?--all-databases?--protocol=tcp

--quick,?-q

不缓冲查询,直接导出到标准输出。默认为打开状态,使用--skip-quick取消该选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases?

mysqldump??-uroot?-p?--host=localhost?--all-databases?--skip-quick

--quote-names,-Q

使用(`)引起表和列名。默认为打开状态,使用--skip-quote-names取消该选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases

mysqldump??-uroot?-p?--host=localhost?--all-databases?--skip-quote-names

--replace

使用REPLACE?INTO?取代INSERT?INTO.

mysqldump??-uroot?-p?--host=localhost?--all-databases?--replace

--result-file,??-r

直接输出到指定文件中。该选项应该用在使用回车换行对(\\r\\n)换行的系统上(例如:DOSWindows)。该选项确保只有一行被使用。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--result-file=/tmp/mysqldump_result_file.txt

--routines,?-R

导出存储过程以及自定义函数。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--routines

--set-charset

添加'SET?NAMES??default_character_set'到输出文件。默认为打开状态,使用--skip-set-charset关闭选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases?

mysqldump??-uroot?-p?--host=localhost?--all-databases?--skip-set-charset

--single-transaction

该选项在导出数据之前提交一个BEGIN?SQL语句,BEGIN?不会阻塞任何应用程序且能保证导出时数据库的一致性状态。它只适用于多版本存储引擎,仅InnoDB。本选项和--lock-tables?选项是互斥的,因为LOCK??TABLES?会使任何挂起的事务隐含提交。要想导出大表的话,应结合使用--quick?选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--single-transaction

--dump-date

将导出时间添加到输出文件中。默认为打开状态,使用--skip-dump-date关闭选项。

mysqldump??-uroot?-p?--host=localhost?--all-databases

mysqldump??-uroot?-p?--host=localhost?--all-databases?--skip-dump-date

--skip-opt

禁用–opt选项.

mysqldump??-uroot?-p?--host=localhost?--all-databases?--skip-opt

--socket,-S

指定连接mysqlsocket文件位置,默认路径/tmp/mysql.sock

mysqldump??-uroot?-p?--host=localhost?--all-databases?--socket=/tmp/mysqld.sock

--tab,-T

为每个表在给定路径创建tab分割的文本文件。注意:仅仅用于mysqldumpmysqld服务器运行在相同机器上。

mysqldump??-uroot?-p?--host=localhost?test?test?--tab="/home/mysql"

--tables

覆盖--databases?(-B)参数,指定需要导出的表名。

mysqldump??-uroot?-p?--host=localhost?--databases?test?--tables?test

--triggers

导出触发器。该选项默认启用,用--skip-triggers禁用它。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--triggers

--tz-utc

在导出顶部设置时区TIME_ZONE='+00:00'?,以保证在不同时区导出的TIMESTAMP?数据或者数据被移动其他时区时的正确性。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--tz-utc

--user,?-u

指定连接的用户名。

--verbose,?--v

输出多种平台信息。

--version,?-V

输出mysqldump版本信息并退出

--where,?-w

只转储给定的WHERE条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--where=?user=root’”

--xml,?-X

导出XML格式.

mysqldump??-uroot?-p?--host=localhost?--all-databases?--xml

--plugin_dir

客户端插件的目录,用于兼容不同的插件版本。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--plugin_dir=/usr/local/lib/plugin

--default_auth

客户端插件默认使用权限。

mysqldump??-uroot?-p?--host=localhost?--all-databases?--default-auth=/usr/local/lib/plugin/

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
MySQL:世界上最受欢迎的数据库的简介MySQL:世界上最受欢迎的数据库的简介Apr 12, 2025 am 12:18 AM

MySQL是一种开源的关系型数据库管理系统,主要用于快速、可靠地存储和检索数据。其工作原理包括客户端请求、查询解析、执行查询和返回结果。使用示例包括创建表、插入和查询数据,以及高级功能如JOIN操作。常见错误涉及SQL语法、数据类型和权限问题,优化建议包括使用索引、优化查询和分表分区。

MySQL的重要性:数据存储和管理MySQL的重要性:数据存储和管理Apr 12, 2025 am 12:18 AM

MySQL是一个开源的关系型数据库管理系统,适用于数据存储、管理、查询和安全。1.它支持多种操作系统,广泛应用于Web应用等领域。2.通过客户端-服务器架构和不同存储引擎,MySQL高效处理数据。3.基本用法包括创建数据库和表,插入、查询和更新数据。4.高级用法涉及复杂查询和存储过程。5.常见错误可通过EXPLAIN语句调试。6.性能优化包括合理使用索引和优化查询语句。

为什么要使用mysql?利益和优势为什么要使用mysql?利益和优势Apr 12, 2025 am 12:17 AM

选择MySQL的原因是其性能、可靠性、易用性和社区支持。1.MySQL提供高效的数据存储和检索功能,支持多种数据类型和高级查询操作。2.采用客户端-服务器架构和多种存储引擎,支持事务和查询优化。3.易于使用,支持多种操作系统和编程语言。4.拥有强大的社区支持,提供丰富的资源和解决方案。

描述InnoDB锁定机制(共享锁,独家锁,意向锁,记录锁,间隙锁,下一键锁)。描述InnoDB锁定机制(共享锁,独家锁,意向锁,记录锁,间隙锁,下一键锁)。Apr 12, 2025 am 12:16 AM

InnoDB的锁机制包括共享锁、排他锁、意向锁、记录锁、间隙锁和下一个键锁。1.共享锁允许事务读取数据而不阻止其他事务读取。2.排他锁阻止其他事务读取和修改数据。3.意向锁优化锁效率。4.记录锁锁定索引记录。5.间隙锁锁定索引记录间隙。6.下一个键锁是记录锁和间隙锁的组合,确保数据一致性。

MySQL查询性能差的常见原因是什么?MySQL查询性能差的常见原因是什么?Apr 12, 2025 am 12:11 AM

MySQL查询性能不佳的原因主要包括没有使用索引、查询优化器选择错误的执行计划、表设计不合理、数据量过大和锁竞争。 1.没有索引导致查询缓慢,添加索引后可显着提升性能。 2.使用EXPLAIN命令可以分析查询计划,找出优化器错误。 3.重构表结构和优化JOIN条件可改善表设计问题。 4.数据量大时,采用分区和分表策略。 5.高并发环境下,优化事务和锁策略可减少锁竞争。

您什么时候应该使用复合索引与多个单列索引?您什么时候应该使用复合索引与多个单列索引?Apr 11, 2025 am 12:06 AM

在数据库优化中,应根据查询需求选择索引策略:1.当查询涉及多个列且条件顺序固定时,使用复合索引;2.当查询涉及多个列但条件顺序不固定时,使用多个单列索引。复合索引适用于优化多列查询,单列索引则适合单列查询。

如何识别和优化MySQL中的慢速查询? (慢查询日志,performance_schema)如何识别和优化MySQL中的慢速查询? (慢查询日志,performance_schema)Apr 10, 2025 am 09:36 AM

要优化MySQL慢查询,需使用slowquerylog和performance_schema:1.启用slowquerylog并设置阈值,记录慢查询;2.利用performance_schema分析查询执行细节,找出性能瓶颈并优化。

MySQL和SQL:开发人员的基本技能MySQL和SQL:开发人员的基本技能Apr 10, 2025 am 09:30 AM

MySQL和SQL是开发者必备技能。1.MySQL是开源的关系型数据库管理系统,SQL是用于管理和操作数据库的标准语言。2.MySQL通过高效的数据存储和检索功能支持多种存储引擎,SQL通过简单语句完成复杂数据操作。3.使用示例包括基本查询和高级查询,如按条件过滤和排序。4.常见错误包括语法错误和性能问题,可通过检查SQL语句和使用EXPLAIN命令优化。5.性能优化技巧包括使用索引、避免全表扫描、优化JOIN操作和提升代码可读性。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具