MySQL数据的备份与还原实现步骤
一、数据备份
1、使用mysqldump命令备份
mysqldump命令将数据库中的数据备份成一个文本文件。表的结构和表中的数据将存储在生成的文本文件中。
mysqldump命令的工作原理很简单。它先查出需要备份的表的结构,再在文本文件中生成一个CREATE语句。然后,将表中的所有记录转换成一条INSERT语句。然后通过这些语句,就能够创建表并插入数据。
1、备份一个数据库
mysqldump基本语法:
mysqldump -u username -p dbname table1 table2 ...-> BackupName.sql
其中:
- dbname参数表示数据库的名称;
- table1和table2参数表示需要备份的表的名称,为空则整个数据库备份;
- BackupName.sql参数表设计备份文件的名称,文件名前面可以加上一个绝对路径。通常将数据库被分成一个后缀名为sql的文件;
使用root用户备份test数据库下的person表
mysqldump -u root -p test person > D:\backup.sql
其生成的脚本如下:
文件的开头会记录MySQL的版本、备份的主机名和数据库名。
文件中以“--”开头的都是SQL语言的注释,以"/*!40101"等形式开头的是与MySQL有关的注释。40101是MySQL数据库的版本号,如果MySQL的版本比1.11高,则/*!40101和*/之间的内容就被当做SQL命令来执行,如果比4.1.1低就会被当做注释。
2、备份多个数据库
语法:
mysqldump -u username -p --databases dbname2 dbname2 > Backup.sql
加上了--databases选项,然后后面跟多个数据库
mysqldump -u root -p --databases test mysql > D:\backup.sql
3、备份所有数据库
mysqldump命令备份所有数据库的语法如下:
mysqldump -u username -p -all-databases > BackupName.sql
示例:
mysqldump -u -root -p -all-databases > D:\all.sql
2、直接复制整个数据库目录
MySQL有一种非常简单的备份方法,就是将MySQL中的数据库文件直接复制出来。这是最简单,速度最快的方法。
不过在此之前,要先将服务器停止,这样才可以保证在复制期间数据库的数据不会发生变化。如果在复制数据库的过程中还有数据写入,就会造成数据不一致。这种情况在开发环境可以,但是在生产环境中很难允许备份服务器。
注意:这种方法不适用于InnoDB存储引擎的表,而对于MyISAM存储引擎的表很方便。同时,还原时MySQL的版本最好相同。
3、使用mysqlhotcopy工具快速备份
一看名字就知道是热备份。因此,mysqlhotcopy支持不停止MySQL服务器备份。而且,mysqlhotcopy的备份方式比mysqldump快。mysqlhotcopy是一个perl脚本,主要在Linux系统下使用。其使用LOCK TABLES、FLUSH TABLES和cp来进行快速备份。
原理:先将需要备份的数据库加上一个读锁,然后用FLUSH TABLES将内存中的数据写回到硬盘上的数据库,最后,把需要备份的数据库文件复制到目标目录。
命令格式如下:
[root@localhost ~]# mysqlhotcopy [option] dbname1 dbname2 backupDir/
- dbname:数据库名称;
- backupDir:备份到哪个文件夹下;
常用选项:
- --help:查看mysqlhotcopy帮助;
- --allowold:如果备份目录下存在相同的备份文件,将旧的备份文件加上_old;
- --keepold:如果备份目录下存在相同的备份文件,不删除旧的备份文件,而是将旧的文件更名;
- --flushlog:本次辈分之后,将对数据库的更新记录到日志中;
- --noindices:只备份数据文件,不备份索引文件;
- --user=用户名:用来指定用户名,可以用-u代替;
- --password=密码:用来指定密码,可以用-p代替。使用-p时,密码与-p之间没有空格;
- --port=端口号:用来指定访问端口,可以用-P代替;
- --socket=socket文件:用来指定socket文件,可以用-S代替;
mysqlhotcopy并非mysql自带,需要安装Perl的数据库接口包;下载地址为:http://dev.mysql.com/downloads/dbi.html
目前,该工具也仅仅能够备份MyISAM类型的表。
二、数据还原
1、还原使用mysqldump命令备份的数据库的语法如下:
mysql -u root -p [dbname] < backup.sq
示例:
mysql -u root -p < C:\backup.sql
2、还原直接复制目录的备份
通过这种方式还原时,必须保证两个MySQL数据库的版本号是相同的。MyISAM类型的表有效,对于InnoDB类型的表不可用,InnoDB表的表空间不能直接复制。
MySQL数据的备份与还原实现步骤相关推荐
- Linux系统下通过命令行对mysql数据进行备份和还原
一.备份 1.进入mysql目录 cd /var/lib/mysql (进入mysql目录,根据安装情况会有差别) 2.备份 mysqldump -u root -p密码 数据库名 数据表名 > ...
- MySQL备份与恢复-使用mysqldump进行数据的备份与还原
使用mysqldump进行数据的备份与还原 备份数据的最终目的是为了在出现一些意外情况时,能够通过备份将数据还原,所以单单的备 份数据往往是无法满足还原时的需求的,所以在备份数据库时,除了要备份数据本 ...
- MySQL中使用innobackupex、xtrabackup进行大数据的备份和还原
大数据量备份与还原,始终是个难点.当MYSQL超10G,用mysqldump来导出就比较慢了.在这里推荐xtrabackup,这个工具比mysqldump要快很多. 本文还参考了:http://blo ...
- Linux下MySQL数据库的备份与还原,mysql快速导入导出数据库实例演示,解决mysql大数据量数据库导出慢的问题
MySQL 数据库的备份与还原 第一章:数据库的导入与导出 ① 数据库的导出 ② 大数据量下 mysqldump 的导出优化 ③ 数据库的导出 第一章:数据库的导入与导出 ① 数据库的导出 需要用到 ...
- MySQL使用命令备份和还原数据库
这篇文章主要介绍了MySQL使用命令备份和还原数据库,本文使用Mysql内置命令实现备份和还原,比较简单,需要的朋友可以参考下 数据库在使用当中都会有数据库备份工作,当数据库发生严重错误无法启动,或者 ...
- 备份从android到ios系统,如何实现iOS和Android的数据传输?如何实现数据的备份和还原?...
如何实现iOS和Android的数据传输?苹果和安卓如何实现数据传输? 这个问题困扰了很多的用户,今天我为大家解答一下. 一.如何实现IOS和Android数据传输? 第一步.首先我们下载安装软件&q ...
- MySQL 数据增量备份
目录 MySQL 数据增量备份 binlog日志 日志概述 启用日志 自定义日志存储目录和日志文件名 手动生成新的日志文件 清理日志(删除已有的日志文件) 查看日志文件内容 使用binlog日志恢复数 ...
- MySQL数据的备份还原及数据修复
在日常的生产环境中为什么要进行备份 备份可以使生产中的数据进行有效的灾难恢复:硬件故障.软件故障.自然灾害.误操作测试等数据丢失场景. 备份注意要点 能容忍最多丢失多少数据 恢复数据需要在多长时间 ...
- 数据库(mysql)数据的备份与还原
(还不会创建数据表的可以看一下我的上一篇链接文章 哦) 1.数据的备份 在已输入字符的数据表内进行: 1.1 返回到mysql安装的bin路径下 输入 :mysqldump -账号 -密码 数据表名& ...
最新文章
- 求职者提问的问题面试官不会_如何通过三个简单的问题就不会陷入求职困境
- 拍照时不会摆Pose怎么办?
- android ios web兼容,js与android iOS 交互兼容
- Ajax同步和异步的区别?
- 2007.2.14 日程安排
- 关于Intel IPP的基本使用方法——参照可设置ipl库
- Unity有哪些让做项目事半功倍的插件值得推荐?
- openssl用法详解
- 王浩算法 c语言,基本遗传算法C语言实现.doc
- 搭建nginx服务器
- 数学建模:人口增长模型
- 打造健康的程序员-饮食篇
- numpy统计图像中某个像素值的个数
- iOS RN学习随笔
- u 只读 盘 突然_U盘变成只读,无法格式化,怎么办?
- NVMe1.4 Admin Command 学习(3)-- fw commit sanitize
- 【读书笔记】c和指针
- Hyperledger Fabric从源码分析交易
- L1-054 福到了 (15分) c++解法
- 什么是人力资源管理系统?hr系统功能介绍
热门文章
- Nature | 我的研究对后人毫无用途:21%的学术论文自发布后从未被引用
- cover-letter
- 1.7 编程基础之字符串 31 字符串p型编码 python
- php mysql实现下拉列表查询_php mysql如何实现通过下拉框查询显示数据库中的数据...
- PHP笔记-所有错误统一输出404页面(详细错误日志输出,提高安全性)
- Linux文档阅读笔记-cut与sort的基本用法
- WEB安全基础-CSRF漏洞
- Java高级语法笔记-字符集与中文编码
- oracle dg 日志手动应用,做了DG之后,日志没有被应用
- java简单编程_「4」Java简单编程