MySQL数据库备份按照格式可以分为两大类:
文本格式的备份:这类备份是通过使用mysqldump程序把数据表内容写到转储文件二得到的,内容主要是由CREATE TABLE和INSERT两种SQL语句构成,把转储文件重新加载到MySQL服务器上就可以恢复有关的数据表。
二进制备份:这类备份是通过直接复制那些包含着数据表内容的文件而得到的。制作这类备份的具体办法有许多种,诸如mysqlhotcopy、cp、tar或rsync之类的程序都可以用来数据库制作二进制备份。
mysqldump程序生成的内容是SQL语句的文本文件,很方面移植,平时用的就是这种方法。
mysqldump程序有许多选项。一下几个选项是比较常用的。
①、通常在mysqldump命令行给出一个数据库名,然后可以在它后面再选择性地给出几个数据表名。如果想一次转储多个数据库,就要使用--databases选项。mysqldump将把你在命令行上给出的名字全部解释为数据库名,并依次转储这些数据库里的所有数据表。如果想转储所有的数据库,可以使用--all-databases选项,此时不需要给出任何数据库名或数据表名参数。这两个参数会在每个数据库输出前插入必要的CREATE DATABASE IF NOT EXISTS和USE语句。
②、在默认情况下,mysqldump程序将同时备份数据表的结构(CREATE TABLE语句)和数据表的内容(INSERT语句)。如果只想备份其中的一种,可以使用--no-create-info或--no-data选项。
③、可以使用--opt选择进行备份优化。默认是启动的,如果不需要,可以shiyong--skip-opt选项禁用。
--opt选项会把正在备份的数据表全部锁定,不让其他人修改。因此在确认无用户需要操作数据库的时候进行备份。
--opt对更新数据表很有用。因为--opt选项自动启动--add-drop-table选项,后者将使mysqldump备份文件里每条CREATE
TABLE语句之爱情你加上一条DROP TABLE IF EXISTS语句。这样你在加载的时候,如果数据表已经存在,也不会发生错误。
④、--opt选项的效果之一是它将启动--extended-insert选项,后者将使mysqldump程序生成可以一次插入多个数据行的INSERT语句。如果想让mysqldump程序生成的INSERT语句每条只插入一个数据行,可以使用--skip-extended-insert选项。
⑤、在备份InnoDB或Falcon数据表的时候,最好使用--single-transaction选项把备份操作放在一个事务里执行,这可以确保得到一个稳定的备份。
⑥、如果数据库包含着存储例程、触发器和事件,可以使用--routing、--triggers和--events选项明确地把它们包括到备份文件里。注意,这个三个选项分别开始于MYSQL5.013、5.0.11、5.1.8版本,如果是在此之前的版本,不支持。同时这几个选项还各有一个--skip形式(例如--skip-triggers)用来禁止备份指定的对象。
在默认是情况下,只有触发器将被包括在备份输入里,存储例程和事件不进入存储。
几个常用用例:
1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc >
wcnc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc users>
wcnc_users.sql
3.导出一个数据库结构
mysqldump -u wcnc -p -d --add-drop-table
smgp_apps_wcnc >d:\wcnc_db.sql
-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop
table
4.导入数据库
常用source 命令
进入mysql数据库控制台,
如mysql -u root -p
mysql>use 数据库
然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:\wcnc_db.sql
分享到:
相关推荐
mysqldump工具基本用法,文档详细介绍了
非常详细的某培训机构mysql学习笔记,内容系统全面,实用性强 MySQL1 MySQL基础 MySQ单实例部署 MySQL多实例部署 MySQL数据库操作 MySQL数据类型 MySQL存储引擎 MySQL表操作 MySQL2 MySQL数据操作 MySQL单...
注意中间的逗号和最后的分号的使用方法。 · 6、一行多命令 输入如下命令: mysql> SELECT USER(); SELECT NOW(); +------------------+ | USER() | +------------------+ | ODBC@localhost | +-----------...
MySQL掌握备份恢复工具mysqldump实践
导出要用到MySQL的mysqldump工具,基本用法是: shell> mysqldump [OPTIONS] database [tables] 如果你不给定任何表,整个数据库将被导出。 通过执行mysqldump –help,你能得到你mysqldump的版本支持的选项表。...
介绍了mysql的两大备份工具的实现原理以及优缺点。从基础概念redo_log、undo_log、MVCC等概念开始阐述,主要适合初学者理解,有的观点是我个人理解,可能存在偏差,分享出来,方便大家阅读和讨论,也欢迎批评指正,...
mysqldump.exe 5.7工具,可以用来导出、导入mysql数据
通过Mysql Source命令能够将SQL文件导入Mysql数据库中,下面通过Mysql导入导出SQL实例详解Mysqldump和Source命令的用法。 Mysql命令行导出工具Mysqldump命令详解 Mysql命令行导出工具Mysqldump.e
08-MySQL逻辑备份工具mysqldump&mysqlpump&mydumper1
Mysql数据备份与mysqldump增量备份.pdf
mysqldump使用方法:可直接使用,备份数据库 使用方法:mysqldump --opt -u用户名 -p密码 -hIP地址 -P数据库端口 要备份的库 > 导入指定的sql里 示例:mysqldump --opt -uroot -p123123 -h192.168.2.10 -P3306 abc >...
导出要用到MySQL的mysqldump工具,基本用法是: 代码如下:shell> mysqldump [OPTIONS] database [tables] 如果你不给定任何表,整个数据库将被导出。 通过执行mysqldump –help,你能得到你mysqldump的版本...
Mysql数据备份与mysqldump增量备份.docx
在低版本备份高版本的时候会报错。可以尝试直接用高版本的mysqldump备份。但是的一个exe文件。