首页 数据库 mysql教程 MySQL中mysqldum数据库的备份和恢复

MySQL中mysqldum数据库的备份和恢复

Jun 07, 2016 pm 05:52 PM
数据备份 数据恢复

在mysql中自带了 mysqldum命令可直接能数据库进行备份和恢复操作,下面我来详细的介绍关于MySQL中mysqldum命令的用法。

1、mysqldump
1.1 备份
mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。现在来讲一下 mysqldump 的一些主要参数:

•--compatible=name
它告诉 mysqldump,导出的数据将和哪种数据库或哪个旧版本的 MySQL 服务器相兼容。值可以为 ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options、no_field_options 等,要使用几个值,用逗号将它们隔开。当然了,它并不保证能完全兼容,而是尽量兼容。

•--complete-insert,-c
导出的数据采用包含字段名的完整 INSERT 方式,也就是把所有的值都写在一行。这么做能提高插入效率,但是可能会受到 max_allowed_packet 参数的影响而导致插入失败。因此,需要谨慎使用该参数,至少我不推荐。

•--default-character-set=charset
指定导出数据时采用何种字符集,如果数据表不是采用默认的 latin1 字符集的话,那么导出时必须指定该选项,否则再次导入数据后将产生乱码问题。

•--disable-keys
告诉 mysqldump 在 INSERT 语句的开头和结尾增加 /*!40000 ALTER TABLE table DISABLE KEYS */; 和 /*!40000 ALTER TABLE table ENABLE KEYS */; 语句,这能大大提高插入语句的速度,因为它是在插入完所有数据后才重建索引的。该选项只适合 MyISAM 表。

•--extended-insert = true|false
默认情况下,mysqldump 开启 --complete-insert 模式,因此不想用它的的话,就使用本选项,设定它的值为 false 即可。

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

•--lock-all-tables,-x
在开始导出之前,提交请求锁定所有数据库中的所有表,以保证数据的一致性。这是一个全局读锁,并且自动关闭 --single-transaction 和 --lock-tables 选项。

•--lock-tables
它和 --lock-all-tables 类似,不过是锁定当前导出的数据表,而不是一下子锁定全部库下的表。本选项只适用于 MyISAM 表,如果是 Innodb 表可以用 --single-transaction 选项。

•--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 选项。本选项能让 mysqldump 很快的导出数据,并且导出的数据能很快导回。该选项默认开启,但可以用 --skip-opt 禁用。注意,如果运行 mysqldump 没有指定 --quick 或 --opt 选项,则会将整个结果集放在内存中。如果导出大数据库的话可能会出现问题。

•--quick,-q
该选项在导出大表时很有用,它强制 mysqldump 从服务器查询取得记录直接输出而不是取得所有记录后将它们缓存到内存中。

•--routines,-R
导出存储过程以及自定义函数。

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

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

其他参数详情请参考手册,我通常使用以下 SQL 来备份 MyISAM 表:

 代码如下 复制代码
/usr/local/mysql/bin/mysqldump -uyejr -pyejr --default-character-set=utf8 --opt --extended-insert=false
--triggers -R --hex-blob -x db_name > db_name.sql

使用以下 SQL 来备份 Innodb 表:

 代码如下 复制代码

/usr/local/mysql/bin/mysqldump -uyejr -pyejr --default-character-set=utf8 --opt --extended-insert=false
--triggers -R --hex-blob --single-transaction db_name > db_name.sql

打开开始->运行->输入cmd进入命令行模式

 代码如下 复制代码

c:>mysqldump -h localhost -u root -p mydb >e:mysqlmydb.sql

然后输入密码,等待一会导出就成功了,可以到目标文件中检查是否成功。

2.将数据库mydb中的mytable导出到e:mysqlmytable.sql文件中:

 代码如下 复制代码

c:>mysqldump -h localhost -u root -p mydb mytable >e:mysqlmytable.sql

3.将数据库mydb的结构导出到e:mysqlmydb_stru.sql文件中:

 代码如下 复制代码

c:>mysqldump -h localhost -u root -p mydb --add-drop-table >e:mysqlmydb_stru.sql

//-h localhost可以省略,其一般在虚拟主机上用


1.2 还原


用 mysqldump 备份出来的文件是一个可以直接倒入的 SQL 脚本,有两种方法可以将数据导入。

从外部文件导入数据到数据库:
例如:

 代码如下 复制代码

/usr/local/mysql/bin/mysql -uyejr -pyejr db_name

从e:mysqlmydb2.sql中将文件中的SQL语句导入数据库中:

 代码如下 复制代码

c:>mysql -h localhost -u root -p mydb2

•用 SOURCE 语法

其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:

 代码如下 复制代码

SOURCE /tmp/db_name.sql;

这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。

进入mysql数据库控制台 : 如 mysql -u root -p

 代码如下 复制代码

mysql>use databasename

然后使用source命令,后面参数为脚本文件(这里用到的是.sql)

 代码如下 复制代码

mysql>source d:mydb.sql


然后输入密码,就OK了


二.命令行进入MYSQL的方法:

 代码如下 复制代码

C:>mysql -h hostname -u username -p

按ENTER键,等待然后输入密码,这里hostname为服务器的名称,如localhost,username为MYSQL的用户名,如root.进入命令行就可以直接操作MYSQL了。


关于导入文件大小限制问题的解决:


默认情况下:mysql对导入的文件大小有限制的,最大为2M,所以当文件很大时,直接无法导入,解决列举如下:

1.在php.ini中修改相关参数:

影响Mysql导入文件大小的参数有三个:

 代码如下 复制代码

memory_limit=128M, upload_max_filesize=2M, post_max_size=8M

修改upload_max_filesize=200M这里修改满足你需要的大小,可以同时修改其他两项memory_limit=250M ,post_max_size=200M.这样就可以导入200M以下的.sql文件了。

上文是把mysql放置在系统路径下,其实不放也可以。如我的mysql安装目录为D:MySQL Server 5.0;则首先打开dos窗口,然后输入D:(没有'')回车;此时应该会出现D:>这样的标志,然后在其后输入D:MySQL Server 5.0bin回车;出现D:MySQL Server 5.0bin>接着输入mysqldump -u root -p 数据库名 >数据库名.sql(也可以输入路径); (具体参照上面)导入文件同样,只是改了'>'为'

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热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中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

diskgenius数据怎么恢复-diskgenius数据恢复教程 diskgenius数据怎么恢复-diskgenius数据恢复教程 Mar 06, 2024 am 09:34 AM

很多小伙伴不知道diskgenius数据怎么恢复,所以下面小编就分享了diskgenius数据恢复的相关教程,一起去看看吧,相信对大家会有帮助。首先,在DiskGenius的主界面上方的硬盘分区图中,可以直接选择目标分区,右键点击。接着,在弹出的快捷菜单中,找到并点击“已删除或格式化后的文件恢复”菜单项,如图所示。在第二步中,弹出恢复选项窗口,确保勾选“恢复已删除的文件”、“完整恢复”和“额外扫描已知文件类型”这三个选项。第三步:点击右侧的“选择文件类型”按钮,在弹出的窗口中指定您需要恢复的文件

PHP参数丢失问题的解决方案 PHP参数丢失问题的解决方案 Mar 11, 2024 am 09:27 AM

PHP参数丢失问题的解决方案在开发PHP程序的过程中,经常会遇到参数丢失的问题,这可能是由于前端传递的参数不完整、后端接收参数的方式不正确等原因造成的。在本文中,我们将针对PHP参数丢失问题提供一些解决方案,并附上具体的代码示例。一、前端传参问题使用GET方法传递参数当使用GET方法传递参数时,参数会以URL参数的形式附加在请求的URL后面。在后端接收参数时

ThinkPHP6数据备份与恢复:保障数据的安全性 ThinkPHP6数据备份与恢复:保障数据的安全性 Aug 13, 2023 am 08:28 AM

ThinkPHP6数据备份与恢复:保障数据的安全性随着互联网的快速发展,数据已成为一项极其重要的资产。因此,数据的安全性备受关注。在Web应用开发中,数据备份与恢复是确保数据安全的重要一环。在本文中,我们将介绍如何使用ThinkPHP6框架进行数据备份与恢复,以保障数据的安全性。一、数据备份数据备份是指将数据库中的数据以某种方式进行复制或存储。这样即使在数据

通过Docker Compose、Nginx和MariaDB实现PHP应用程序的数据备份与还原 通过Docker Compose、Nginx和MariaDB实现PHP应用程序的数据备份与还原 Oct 12, 2023 am 11:14 AM

通过DockerCompose、Nginx和MariaDB实现PHP应用程序的数据备份与还原随着云计算和容器化技术的快速发展,越来越多的应用程序选择使用Docker来部署和运行。在Docker生态系统中,DockerCompose是一个非常受欢迎的工具,它可以通过一个单一的配置文件来定义和管理多个容器。本文将介绍如何使用DockerCompose、Ng

如何在Laravel中使用中间件进行数据恢复 如何在Laravel中使用中间件进行数据恢复 Nov 02, 2023 pm 02:12 PM

Laravel是一个流行的PHPWeb应用程序框架,提供了许多快速而又简单的方式来构建高效、安全和可扩展的Web应用程序。在开发Laravel应用程序时,我们经常需要考虑数据恢复的问题,即如何在数据丢失或损坏的情况下恢复数据并保证应用程序的正常运行。在本文中,我们将介绍如何使用Laravel中间件来实现数据恢复功能,并提供具体的代码示例。一、什么是Lara

如何处理硬盘扇区损坏问题 如何处理硬盘扇区损坏问题 Feb 19, 2024 am 11:03 AM

硬盘扇区坏了怎么解决硬盘扇区坏了是一个常见的硬件故障,它可能导致数据丢失,影响计算机的性能。了解和解决硬盘扇区坏了的问题是非常重要的。本文将介绍硬盘扇区的概念,讨论常见的硬盘扇区坏了的原因以及解决办法。一、什么是硬盘扇区?在介绍如何解决硬盘扇区坏了的问题之前,我们首先来了解一下什么是硬盘扇区。硬盘扇区是硬盘驱动器上最小的可读写单元,它是硬盘中的一小段空间,用

如何处理C++大数据开发中的数据备份一致性问题? 如何处理C++大数据开发中的数据备份一致性问题? Aug 26, 2023 pm 11:15 PM

如何处理C++大数据开发中的数据备份一致性问题?在C++大数据开发中,数据备份是非常重要的一环。为了确保数据备份的一致性,我们需要采取一系列的措施来解决这个问题。本文将探讨如何处理C++大数据开发中的数据备份一致性问题,并提供相应的代码示例。使用事务进行数据备份事务是一种保证数据操作的一致性的机制。在C++中,我们可以使用数据库中的事务概念来实现数据备份的一

如何快速恢复MySQL数据库遭遇的故障和错误? 如何快速恢复MySQL数据库遭遇的故障和错误? Sep 10, 2023 pm 03:45 PM

如何快速恢复MySQL数据库遭遇的故障和错误?MySQL是一种广泛使用的开源关系型数据库管理系统,许多应用程序和网站都依赖于它来存储和管理数据。然而,数据库故障和错误是不可避免的,这可能导致数据丢失或应用程序无法正常运行。在遭遇MySQL数据库故障或错误时,快速而有效地恢复数据库非常重要。本文将介绍一些快速恢复MySQL数据库的方法。确定故障和错误的类型在开

See all articles