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?相兼容。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_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
使用十六进制格式导出二进制字符串字段。如果有二进制数据就必须使用该选项。影响到的字段类型有BINARY、VARBINARY、BLOB。
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=
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表并行插入。对于支持事务的表例如InnoDB和BDB,--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/IP和socket连接的缓存大小。
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)换行的系统上(例如:DOS,Windows)。该选项确保只有一行被使用。
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
指定连接mysql的socket文件位置,默认路径/tmp/mysql.sock
mysqldump??-uroot?-p?--host=localhost?--all-databases?--socket=/tmp/mysqld.sock
--tab,-T
为每个表在给定路径创建tab分割的文本文件。注意:仅仅用于mysqldump和mysqld服务器运行在相同机器上。
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/

命名管道是一种在操作系统中相对比较低级的进程通信方式,它是一种以文件为中介的进程通信方式。在Go语言中,通过os包提供了对命名管道的支持。在本文中,我们将介绍如何在Go中使用命名管道来实现进程间通信。一、命名管道的概念命名管道是一种特殊的文件,可以被多个进程同时访问。在Linux系统中,命名管道是一种特殊的文件类型,它们存在于文件系统的某个位置上,并且可以在

在Go语言中,使用第三方库是非常方便的。许多优秀的第三方库和框架可以帮助我们快速地开发应用程序,同时也减少了我们自己编写代码的工作量。但是如何正确地使用第三方库,确保其稳定性和可靠性,是我们必须了解的一个问题。本文将从以下几个方面介绍如何使用第三方库,并结合具体例子进行讲解。一、第三方库的获取Go语言中获取第三方库有以下两种方式:1.使用goget命令首先

随着传统的多线程模型在高并发场景下的性能瓶颈,协程成为了PHP编程领域的热门话题。协程是一种轻量级的线程,能够在单线程中实现多任务的并发执行。在PHP的语言生态中,协程得到了广泛的应用,比如Swoole、Workerman等框架就提供了对协程的支持。那么,如何在PHP中使用协程呢?本文将介绍一些基本的使用方法以及常见的注意事项,帮助读者了解协程的运作原理,以

变量函数是指可以使用变量来调用函数的一种特殊语法。在PHP中,变量函数是非常有用的,因为它可以让我们更加灵活地使用函数。在本文中,我们将介绍如何在PHP中使用变量函数。定义变量函数在PHP中,变量函数的定义方式非常简单,只需要将要调用的函数名赋值给一个变量即可。例如,下面的代码定义了一个变量函数:$func='var_dump';这里将var_dump函

近年来,WebSocket技术已经成为了Web开发中不可或缺的一部分。WebSocket是一种在单个TCP连接上进行全双工通信的协议,它使得客户端和服务器之间的通信更加流畅和高效。如今,很多现代的Web应用程序都使用了WebSocket技术,例如实时聊天、在线游戏以及实时数据可视化等。Go语言作为一个现代的编程语言,自然也提供了很好的支持WebSock

<p>Windows 系统上的 OneDrive 应用程序允许您将文件存储在高达 5 GB 的云上。OneDrive 应用程序中还有另一个功能,它允许用户选择一个选项,是将文件保留在系统空间上还是在线提供,而不占用您的系统存储空间。此功能称为按需文件。在这篇文章中,我们进一步探索了此功能,并解释了有关如何在 Windows 11 电脑上的 OneDrive 中按需使用文件的各种选项。</p><h2>如何使用 On

随着音频处理在各种应用场景中的普及,越来越多的程序员开始使用Go编写音频处理程序。Go语言作为一种现代化的编程语言,具有优秀的并发性和高效率的特点,使用它进行音频处理十分方便。本文将介绍如何在Go中使用音频处理技术,包括读取、写入、处理和分析音频数据等方面的内容。一、读取音频数据在Go中读取音频数据有多种方式。其中比较常用的是使用第三方库进行读取,比如go-

数据聚合函数是一种用于处理数据库表中多行数据的函数。在PHP中使用数据聚合函数可以使得我们方便地进行数据分析和处理,例如求和、平均数、最大值、最小值等。下面将介绍如何在PHP中使用数据聚合函数。一、介绍常用的数据聚合函数COUNT():计算某一列的行数。SUM():计算某一列的总和。AVG():计算某一列的平均值。MAX():取出某一列的最大值。MIN():


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 English version
Recommended: Win version, supports code prompts!

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)
