阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL数据备份mysqldump的简单使用

141次阅读
没有评论

共计 5996 个字符,预计需要花费 15 分钟才能阅读完成。

MySQLdump 是一个数据库逻辑备份程序,可以使用对一个或者多个 mysql 数据库进行备份或者将数据传输到其他 mysql 服务器。执行 mysqldump 时需要账户拥有 select 权限才可以进行备份数据表,show view 权限用于备份视图,trigger 权限用于备份触发器等。

mysqldump 不是大数据备份的解决方案,因为 mysqldump 需要通过重建 sql 语句来实现备份功能,对于数据量比较大的数据库备份与还原操作,速度比较慢,打开 mysqldump 备份会发现里面其实就是数据库 sql 语句的重现。

对于大规模的数据备份与还原,使用物理服备份会更加合适,通过直接复制数据文件,即可实现快速的数据还原工作。

使用 mysqldump 可以备份数据库中的某些数据表,也可以备份整个数据库,还可以备份 mysql 系统中的所有数据库,对于使用 mysqldump 工具备份的数据库,可以使用 mysql 的命令工具还原数据。

语法格式如下:

mysqldump [选项] db_name [table_name]

mysqldump [选项] –databases db_name

mysqldump [选型] –all-databases

mysqldump 选项如下所示,同时这些选项也可以通过 [mysqldump] 和[client]写入配置文件中

–all-databases , -A

导出全部数据库。

–all-tablespaces , -Y

导出全部表空间。

–no-tablespaces , -y

不导出任何表空间信息。

–add-drop-database

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

–add-drop-table

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

–add-locks

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

–allow-keywords

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

–apply-slave-statements

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

–character-sets-dir

字符集文件的目录

–comments

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

–compatible

导出的数据将和其它数据库或旧版本的 MySQL 相兼容。值可以为 ansi、mysql323、mysql40、postgresql、Oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,

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

–compact

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

–complete-insert, -c

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

–compress, -C

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

–create-options, -a

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

–databases, -B

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

–debug

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

–debug-check

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

–debug-info

输出调试信息并退出

–default-character-set

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

–delayed-insert

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

–delete-master-logs

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

–disable-keys

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

–dump-slave

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

–events, -E

导出事件。

–extended-insert, -e

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

–fields-terminated-by

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

–fields-enclosed-by

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

–fields-optionally-enclosed-by

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

–fields-escaped-by

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

–flush-logs

开始导出之前刷新日志。

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

–flush-privileges

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

–force

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

–help

显示帮助信息并退出。

–hex-blob

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

–host, -h

需要导出的主机信息

–ignore-table

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

–include-master-host-port

在 –dump-slave 产生的 ’CHANGE MASTER TO..’ 语句中增加 ’MASTER_HOST=<host>,MASTER_PORT=<port>’

–insert-ignore

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

–lines-terminated-by

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

–lock-all-tables, -x

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

–lock-tables, -l

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

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

–log-error

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

–master-data

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

–max_allowed_packet

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

–net_buffer_length

TCP/IP 和 socket 连接的缓存大小。

–no-autocommit

使用 autocommit/commit 语句包裹表。

–no-create-db, -n

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

–no-create-info, -t

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

–no-data, -d

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

–no-set-names, -N

等同于 –skip-set-charset

–opt

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

–order-by-primary

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

–password, -p

连接数据库密码

–pipe(windows 系统可用)

使用命名管道连接 mysql

–port, -P

连接数据库端口号

–protocol

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

–quick, -q

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

–quote-names,-Q

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

–replace

使用 REPLACE INTO 取代 INSERT INTO.

–result-file, -r

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

–routines, -R

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

–set-charset

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

–single-transaction

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

–dump-date

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

–skip-opt

禁用–opt 选项.

–socket,-S

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

–tab,-T

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

–tables

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

–triggers

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

–tz-utc

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

–user, -u

指定连接的用户名。

–verbose, –v

输出多种平台信息。

–version, -V

输出 mysqldump 版本信息并退出

–where, -w

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

–xml, -X

导出 XML 格式.

–plugin_dir

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

–default_auth

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

常用命令如下:

备份所有的数据库:

mysqldump -u root -p –all-databasese > all_databaes_sql

备份 mysql 数据库:

mysqldump -u root -p –database mysql > mysql_databases_sql

备份 mysql 数据库下的 user 数据表:

mysqldump -u root -p mysql user > user_table

使用 all_databases_sql 数据库备份文件还原数据库

mysql -u root -p < all_database_sql

使用 mysql_database_sql 数据库备份文件还原数据库

mysql -u root -p mysql < nmysql_databases_sql

使用 user_table 数据库备份文件还原数据库

mysql -u root -p mysql < user_table

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-22发表,共计5996字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中