mysqldump命令导入导出数据库方法与实例汇总

mysqldump命令的用法

1、导出所有库

系统命令行

mysqldump -uusername -ppassword --all-databases > all.sql

2、导入所有库

mysql命令行

mysql>source all.sql;

3、导出某些库

系统命令行

mysqldump -uusername -ppassword --databases db1 db2 > db1db2.sql

4、导入某些库

mysql命令行

mysql>source db1db2.sql;

5、导入某个库

系统命令行

mysql -uusername -ppassword db1 < db1.sql;

或mysql命令行

mysql>source db1.sql;

6、导出某些数据表

系统命令行

mysqldump -uusername -ppassword db1 table1 table2 > tb1tb2.sql

7、导入某些数据表

系统命令行

mysql -uusername -ppassword db1 < tb1tb2.sql

或mysql命令行

mysql>
user db1;
source tb1tb2.sql;

8、mysqldump字符集设置

mysqldump -uusername -ppassword --default-character-set=gb2312 db1 table1 > tb1.sql

mysqldump客户端可用来转储数据库或搜集数据库进行备份或将数据转移到另一个sql服务器(不一定是一个mysql服务器)。转储包含创建表和/或装载表的sql语句。
如果在服务器上进行备份,并且表均为myisam表,应考虑使用mysqlhotcopy,因为可以更快地进行备份和恢复。

有3种方式来调用mysqldump:

shell> mysqldump [options] db_name [tables]
shell> mysqldump [options] ---database db1 [db2 db3...]
shell> mysqldump [options] --all--database

如果没有指定任何表或使用了---database或--all--database选项,则转储整个数据库。
要想获得你的版本的mysqldump支持的选项,执行mysqldump ---help。

如果运行mysqldump没有--quick或--opt选项,mysqldump在转储结果前将整个结果集装入内存。如果转储大数据库可能会出现问题。该选项默认启用,但可以用--skip-opt禁用。
如果使用最新版本的mysqldump程序生成一个转储重装到很旧版本的mysql服务器中,不应使用--opt或-e选项。
mysqldump支持下面的选项:

---help,-?

显示帮助消息并退出。

--add-drop--database

在每个create database语句前添加drop database语句。

--add-drop-tables

在每个create table语句前添加drop table语句。

--add-locking

用lock tables和unlock tables语句引用每个表转储。重载转储文件时插入得更快。

--all--database,-a

转储所有数据库中的所有表。与使用---database选项相同,在命令行中命名所有数据库。

--allow-keywords

允许创建关键字列名。应在每个列名前面加上表名前缀。

---comments[={0|1}]

如果设置为 0,禁止转储文件中的其它信息,例如程序版本、服务器版本和主机。--skip—comments与---comments=0的结果相同。 默认值为1,即包括额外信息。

--compact

产生少量输出。该选项禁用注释并启用--skip-add-drop-tables、--no-set-names、--skip-disable-keys和--skip-add-locking选项。

--compatible=name

产生与其它数据库系统或旧的mysql服务器更兼容的输出。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options或者no_field_options。要使用几个值,用逗号将它们隔开。这些值与设置服务器sql模式的相应选项有相同的含义。

该选项不能保证同其它服务器之间的兼容性。它只启用那些目前能够使转储输出更兼容的sql模式值。例如,--compatible=oracle 不映射oracle类型或使用oracle注释语法的数据类型。

--complete-insert,-c

使用包括列名的完整的insert语句。

--compress,-c

压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。

--create-option

在create table语句中包括所有mysql表选项。

---database,-b

转储几个数据库。通常情况,mysqldump将命令行中的第1个名字参量看作数据库名,后面的名看作表名。使用该选项,它将所有名字参量看作数据库名。create database if not exists db_name和use db_name语句包含在每个新数据库前的输出中。

---debug[=debug_options],-# [debug_options]

写调试日志。debug_options字符串通常为'd:t:o,file_name'。

--default-character-set=charset
 使用charsetas默认字符集。如果没有指定,mysqldump使用utf8。
 --delayed-insert
 使用insert delayed语句插入行。
 --delete-master-logs
 在主复制服务器上,完成转储操作后删除二进制日志。该选项自动启用--master-data。
 --disable-keys,-k
 对于每个表,用/*!40000 alter table tbl_name disable keys */;和/*!40000 alter table tbl_name enable keys */;语句引用insert语句。这样可以更快地装载转储文件,因为在插入所有行后创建索引。该选项只适合myisam表。
 --extended-insert,-e
 使用包括几个values列表的多行insert语法。这样使转储文件更小,重载文件时可以加速插入。
 --fields-terminated-by=...,--fields-enclosed-by=...,--fields-optionally-enclosed-by=...,--fields-escaped-by=...,--行-terminated-by=...
 这些选项结合-t选项使用,与load data infile的相应子句有相同的含义。
 --first-slave,-x
 不赞成使用,现在重新命名为--lock-all-tables。
 --flush-logs,-f
 开始转储前刷新mysql服务器日志文件。该选项要求reload权限。请注意如果结合--all--database(或-a)选项使用该选项,根据每个转储的数据库刷新日志。例外情况是当使用--lock-all-tables或--master-data的时候:在这种情况下,日志只刷新一次,在所有 表被锁定后刷新。如果你想要同时转储和刷新日志,应使用--flush-logs连同--lock-all-tables或--master-data。
 --force,-f
 在表转储过程中,即使出现sql错误也继续。
 --host=host_name,-h host_name
 从给定主机的mysql服务器转储数据。默认主机是localhost。
 --hex-blob
 使用十六进制符号转储二进制字符串列(例如,'abc' 变为0x616263)。影响到的列有binary、varbinary、blob。
 --lock-all-tables,-x
 所有数据库中的所有表加锁。在整体转储过程中通过全局读锁定来实现。该选项自动关闭--single-transaction和--lock-tables。
 --lock-tables,-l
 开始转储前锁定所有表。用read local锁定表以允许并行插入myisam表。对于事务表例如innodb和bdb,--single-transaction是一个更好的选项,因为它不根本需要锁定表。
 请注意当转储多个数据库时,--lock-tables分别为每个数据库锁定表。因此,该选项不能保证转储文件中的表在数据库之间的逻辑一致性。不同数据库表的转储状态可以完全不同。
 --master-data[=value]
 该选项将二进制日志的位置和文件名写入到输出中。该选项要求有reload权限,并且必须启用二进制日志。如果该选项值等于1,位置和文件名被写入change master语句形式的转储输出,如果你使用该sql转储主服务器以设置从服务器,从服务器从主服务器二进制日志的正确位置开始。如果选项值等于2,change master语句被写成sql注释。如果value被省略,这是默认动作。
 --master-data选项启用--lock-all-tables,除非还指定--single-transaction(在这种情况下,只在刚开始转储时短时间获得全局读锁定。又见--single-transaction。在任何一种情况下,日志相关动作发生在转储时。该选项自动关闭--lock-tables。
 --no-create-db,-n
 该选项禁用create database /*!32312 if not exists*/ db_name语句,如果给出---database或--all--database选项,则包含到输出中。
 --no-create-info,-t
 不写重新创建每个转储表的create table语句。
 --no-data,-d
 不写表的任何行信息。如果你只想转储表的结构这很有用。
 --opt
 该选项是速记;等同于指定 --add-drop-tables--add-locking --create-option --disable-keys--extended-insert --lock-tables --quick --set-charset。它可以给出很快的转储操作并产生一个可以很快装入mysql服务器的转储文件。该选项默认开启,但可以用--skip-opt禁用。要想只禁用确信用-opt启用的选项,使用--skip形式;例如,--skip-add-drop-tables或--skip-quick。
 --password[=password],-p[password]
 连接服务器时使用的密码。如果你使用短选项形式(-p),不能在选项和密码之间有一个空格。如果在命令行中,忽略了--password或-p选项后面的 密码值,将提示你输入一个。
 --port=port_num,-p port_num
 用于连接的tcp/ip端口号。
 --protocol={tcp | socket | pipe | memory}
 使用的连接协议。
 --quick,-q
 该选项用于转储大的表。它强制mysqldump从服务器一次一行地检索表中的行而不是检索所有行并在输出前将它缓存到内存中。
 --quote-names,-q
 用‘`'字符引用数据库、表和列名。如果服务器sql模式包括ansi_quotes选项,用‘"'字符引用名。默认启用该选项。可以用--skip-quote-names禁用,但该选项应跟在其它选项后面,例如可以启用--quote-names的--compatible。
 --result-file=file,-r file
 将输出转向给定的文件。该选项应用在windows中,因为它禁止将新行‘\n'字符转换为‘\r\n'回车、返回/新行序列。
 --routines,-r
 在转储的数据库中转储存储程序(函数和程序)。使用---routines产生的输出包含create procedure和create function语句以重新创建子程序。但是,这些语句不包括属性,例如子程序定义者或创建和修改时间戳。这说明当重载子程序时,对它们进行创建时定义者应设置为重载用户,时间戳等于重载时间。
 如果你需要创建的子程序使用原来的定义者和时间戳属性,不使用--routines。相反,使用一个具有mysql数据库相应权限的mysql账户直接转储和重载mysql.proc表的内容。
 该选项在mysql 5.1.2中添加进来。在此之前,存储程序不转储。
 --set-charset
 将set names default_character_set加到输出中。该选项默认启用。要想禁用set names语句,使用--skip-set-charset。
 --single-transaction
 该选项从服务器转储数据之前发出一个begin sql语句。它只适用于事务表,例如innodb和bdb,因为然后它将在发出begin而没有阻塞任何应用程序时转储一致的数据库状态。
 当使用该选项时,应记住只有innodb表能以一致的状态被转储。例如,使用该选项时任何转储的myisam或heap表仍然可以更改状态。
 --single-transaction选项和--lock-tables选项是互斥的,因为lock tables会使任何挂起的事务隐含提交。
 要想转储大的表,应结合--quick使用该选项。
 --socket=path,-s path
 当连接localhost(为默认主机)时使用的套接字文件。
 --skip--comments
 参见---comments选项的描述。
 --tab=path,-t path
 产生tab分割的数据文件。对于每个转储的表,mysqldump创建一个包含创建表的create table语句的tbl_name.sql文件,和一个包含其数据的tbl_name.txt文件。选项值为写入文件的目录。
 默认情况,.txt数据文件的格式是在列值和每行后面的新行之间使用tab字符。可以使用--fields-xxx和--行--xxx选项明显指定格式。
 注释:该选项只适用于mysqldump与mysqld服务器在同一台机器上运行时。你必须具有file权限,并且服务器必须有在你指定的目录中有写文件的许可。
 --tables
 覆盖---database或-b选项。选项后面的所有参量被看作表名。
 --triggers
 为每个转储的表转储触发器。该选项默认启用;用--skip-triggers禁用它。
 --tz-utc
 在转储文件中加入set time_zone='+00:00'以便timestamp列可以在具有不同时区的服务器之间转储和重载。(不使用该选项,timestamp列在具有本地时区的源服务器和目的服务器之间转储和重载)。--tz-utc也可以保护由于夏令时带来的更改。--tz-utc默认启用。要想禁用它,使用--skip-tz-utc。该选项在mysql 5.1.2中加入。
 --user=user_name,-u user_name
 连接服务器时使用的mysql用户名。
 --verbose,-v
 冗长模式。打印出程序操作的详细信息。
 --version,-v
 显示版本信息并退出。
 --where='where-condition', -w 'where-condition'
 只转储给定的where条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。
 例如:
 "--where=user='jimf'"
 "-wuserid>1"
 "-wuserid<1"
 --xml,-x
 将转储输出写成xml。
 还可以使用--var_name=value选项设置下面的变量:
 max_allowed_packet
 客户端/服务器之间通信的缓存区的最大大小。最大为1gb。
 net_buffer_length
 客户端/服务器之间通信的缓存区的初始大小。当创建多行插入语句时(如同使用选项--extended-insert或--opt),mysqldump创建长度达net_buffer_length的行。如果增加该变量,还应确保在mysql服务器中的net_buffer_length变量至少这么大。
 还可以使用--set-variable=var_name=value或-o var_name=value语法设置变量。然而,现在不赞成使用该语法。
 mysqldump最常用于备份一个整个的数据库:
shell> mysqldump --opt db_name > backup-file.sql

可以这样将转储文件读回到服务器:

shell> mysql db_name < backup-file.sql

或者为:

shell> mysql -e "source /path-to--backup/backup-file.sql" db_name

mysqldump也可用于从一个mysql服务器向另一个服务器复制数据时装载数据库:
shell> mysqldump --opt db_name | mysql --host=remote_host -c db_name

可以用一个命令转储几个数据库:
shell> mysqldump ---database db_name1 [db_name2 ...] > my_databases.sql

如果想要转储所有数据库,使用--all--database选项:

shell> mysqldump --all-databases > all_databases.sql

如果表保存在innodb存储引擎中,mysqldump提供了一种联机备份的途径(参见下面的命令)。该备份只需要在开始转储时对所有表进行全局读锁定(使用flush tables with read lock)。获得锁定后,读取二进制日志的相应内容并将锁释放。因此如果并且只有当发出flush...时正执行一个长的更新语句,mysql服务器才停止直到长语句结束,然后转储则释放锁。因此如果mysql服务器只接收到短("短执行时间")的更新语句,即使有大量的语句,也不会注意到锁期间。

shell> mysqldump --all-databases --single-transaction > all_databases.sql

对于点对点恢复(也称为“前滚”,当你需要恢复旧的备份并重放该备份以后的更改时),循环二进制日志或至少知道转储对应的二进制日志内容很有用:

shell> mysqldump --all-databases --master-data=2 > all_databases.sql
 或

shell> mysqldump --all-databases --flush-logs --master-data=2 > all_databases.sql

如果表保存在innodb存储引擎中,同时使用--master-data和--single-transaction提供了一个很方便的方式来进行适合点对点恢复的联机备份。

(0)

相关推荐

  • mysql数据库备份及恢复命令 mysqldump,source的用法

    还原一个数据库:mysql -h localhost -u root -p123456 www<c:\www.sql 备份一个数据库:mysqldump -h localhost -u root -p123456 www > d:\www2008-2-26.sql //以下是在程序中进行测试 //$command = "mysqldump --opt -h $dbhost -u $dbuser -p $dbpass $dbname | gzip > $backupFile&qu

  • 使用MySQL MySqldump命令导出数据时的注意事项

    今天使用mysqldump命令备份数据的时候出现了一个问题. 一开始迁移 Discuz 7 论坛的 mysql 数据库时,采用 mysqldump 命令的时候一切顺利,但导入的时候却遇到了  ERROR 1062 (xxxxx) at line 1262: Duplicate entry 'XXX' for key 'XXX' 错误,并停在原地. 对于遇到相同错误的朋友千万别第一时间就尝试用 –force 参数强行导入(除非你原来的数据库已经崩溃).因为这样做的话,即使导入了,也会有一大片数据丢

  • PHP使用mysqldump命令导出数据库

    PHP使用外部命令导出数据库,代码很简单,就不多废话了 <?php // $dumpFileName目录要有可写权限 $DbHost = 'localhost'; $DbUser = 'root'; $DbPwd = '123456'; $DbName = 'a'; $fileName = $DbName . '_MySQL_data_backup_' . date('YmdHis) . '.sql'; $dumpFileName= "/var/$fileName"; heade

  • Linux中mysqldump命令实例详解

    mysqldump是mysql数据库中备份工具,用于将MYSQL服务器中的数据库以标准的sql语言的方式导出,并保存到文件中. 语法: mysqldump (选项) 选项: --add-drop-table :在每个创建数据表语句前添加删除数据库的语句  --add-locks:备份数据库表时锁定数据库表  --all-databases:备份mysql服务器上的所有数据库  --comments:添加注释信息  --compact:压缩模式,产生更少的输出  --complete-insert

  • Mysql导入导出工具Mysqldump和Source命令用法详解

    在PHP网站开发中,时常遇到Mysql数据库备份或数据库迁移工作,这时Mysql怎么导入导出数据库中的数据就非常关键,Mysql本身提供了命令行导出工具Mysqldump和Mysql Source导入命令进行SQL数据导入导出工作,通过Mysql命令行导出工具Mysqldump命令能够将Mysql数据导出为文本格式(txt)的SQL文件,通过Mysql Source命令能够将SQL文件导入Mysql数据库中,下面通过Mysql导入导出SQL实例详解Mysqldump和Source命令的用法. M

  • MySQL mysqldump命令使用详解

    经常地备份可以帮助防止宝贵数据地丢失:另外一个原因是,也许您希望导出数据来共享. 在这个信息技术不断成长的世界中,共享数据变得越来越常见.    比方说Macmillan USA维护护着一个将要出版的书籍的大型数据库.这个数据库在许多书店之间共享,这样他们就知道哪些书将会很快出版.医院越来越走向采用无纸病历记录,这样这些病历可以随时跟着你.世界变得越来越小,信息也被共享得越来越多.有很多中导出数据得方法,它们都跟导入数据很相似.因为,毕竟,这些都只是一种透视得方式.从数据库导出的数据就是从另一端

  • mysqldump命令导入导出数据库方法与实例汇总

    mysqldump命令的用法 1.导出所有库 系统命令行 mysqldump -uusername -ppassword --all-databases > all.sql 2.导入所有库 mysql命令行 mysql>source all.sql; 3.导出某些库 系统命令行 mysqldump -uusername -ppassword --databases db1 db2 > db1db2.sql 4.导入某些库 mysql命令行 mysql>source db1db2.s

  • MYSQL命令行导入导出数据库详解

    Mysql命令行导入数据库: 1,将要导入的.sql文件移至bin文件下,这样的路径比较方便 2,同上面导出的第1步 3,进入MySQL:mysql -u 用户名 -p 如我输入的命令行:mysql -u root -p   (输入同样后会让你输入MySQL的密码) 4,在MySQL-Front中新建你要建的数据库,这时是空数据库,如新建一个名为news的目标数据库 5,输入:mysql>use 目标数据库名 如我输入的命令行:mysql>use news; 6,导入文件:mysql>s

  • Java实现Excel导入导出数据库的方法示例

    本文实例讲述了Java实现Excel导入导出数据库的方法.分享给大家供大家参考,具体如下: 由于公司需求,想通过Excel导入数据添加到数据库中,而导入的Excel的字段是不固定的,使用得通过动态创建数据表,每个Excel对应一张数据表,怎么动态创建数据表,可以参考前面一篇<java使用JDBC动态创建数据表及SQL预处理的方法>. 下面主要讲讲怎么将Excel导入到数据库中,直接上代码:干货走起~~ ExcellToObjectUtil 类 主要功能是讲Excel中的数据导入到数据库中,有几

  • Python之csv文件从MySQL数据库导入导出的方法

    Python从MySQL数据库中导出csv文件处理 csv文件导入MySQL数据库 import pymysql import csv import codecs def get_conn(): conn = pymysql.connect(host='localhost', port=3306, user='root', passwd='root', db='test_csv', charset='utf8') return conn def insert(cur, sql, args): c

  • LINUX下Oracle数据导入导出的方法详解

    本文讲述了LINUX下Oracle数据导入导出的方法.分享给大家供大家参考,具体如下: 一. 导出工具 exp 1. 它是操作系统下一个可执行的文件 存放目录/ORACLE_HOME/bin exp导出工具将数据库中数据备份压缩成一个二进制系统文件.可以在不同OS间迁移   它有三种模式: a.  用户模式: 导出用户所有对象以及对象中的数据: b.  表模式: 导出用户所有表或者指定的表: c.  整个数据库: 导出数据库中所有对象. 2. 导出工具exp交互式命令行方式的使用的例子: $ex

  • docker 使用mysqldump命令备份导出项目中的mysql数据

    mysqldump命令 介绍:一个数据库备份程序 格式:mysqldump [options] [db_name [tbl_name ...]]描述:mysqldump客户端实用程序执行逻辑备份,生成一组SQL语句,可以执行这些语句来重现原始数据库对象定义和表数据.它转储一个或多个MySQL数据库以备份或传输到另一个SQL服务器. mysqldump命令还可以生成CSV,其他分隔文本或XML格式的输出. 下图为镜像重命名后的镜像名为uoj,现在要把这个镜像中的mysql导出 运行如下命令: do

  • SpringBoot+Vue实现EasyPOI导入导出的方法详解

    目录 前言 一.为什么做导入导出 二.什么是 EasyPOI 三.项目简介 项目需求 效果图 开发环境 四.实战开发 核心源码 前端页面 后端核心实现 五.项目源码 小结 前言 Hello~ ,前后端分离系列和大家见面了,秉着能够学到知识,学会知识,学懂知识的理念去学习,深入理解技术! 项目开发过程中,很大的需求都有 导入导出功能,我们依照此功能,来实现并还原真实企业开发中的实现思路 一.为什么做导入导出 为什么做导入导出 导入 在项目开发过程中,总会有一些统一的操作,例如插入数据,系统支持单个

  • ASP.NET开源导入导出库Magicodes.IE完成Csv导入导出的方法

    说明 本章主要说明如何使用Magicodes.IE.Csv进行Csv导入导出. 关于Magicodes.IE 导入导出通用库,通过导入导出DTO模型来控制导入和导出,支持Excel.Word.Pdf和Html. GitHub地址:https://github.com/xin-lai/Magicodes.IE 主要步骤 1.安装包Magicodes.IE.Csv Install-Package Magicodes.IE.Csv 2.使用Magicodes.IE.Csv导出Csv 通过如下代码片段我

  • mysql 导入导出数据库、数据表的方法

    Linux下均在控制台下操作.导入数据库:前提:数据库和数据表要存在(已经被创建) (1)将数据表 test_user.sql 导入到test 数据库的test_user 表中[root@test ~]# mysql -uroot -p test < /www/web/test/test_user.sql (2) 将数据库 test.sql 导入到 test 数据库test 中[root@test ~]# mysql -uroot -p test < /www/web/test/test.sq

  • 解析PL/SQL Developer导入导出数据库的方法以及说明

    PL/SQL Developer是Oracle数据库中用于导入或导出数据库的主要工具,本文主要介绍了利用PL/SQL Developer导入和导出数据库的过程,并对导入或导出时的一些注意事项进行了说明,接下来我们就一一介绍. 导出步骤:    1 tools ->export user object 选择选项,导出.sql文件.    2 tools ->export tables-> Oracle Export 选择选项导出.dmp文件.导入步骤:    注:导入之前最好把以前的表删除

随机推荐