一、数据备份

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数据的备份与还原实现步骤相关推荐

  1. Linux系统下通过命令行对mysql数据进行备份和还原

    一.备份 1.进入mysql目录 cd /var/lib/mysql (进入mysql目录,根据安装情况会有差别) 2.备份 mysqldump -u root -p密码 数据库名 数据表名 > ...

  2. MySQL备份与恢复-使用mysqldump进行数据的备份与还原

    使用mysqldump进行数据的备份与还原 备份数据的最终目的是为了在出现一些意外情况时,能够通过备份将数据还原,所以单单的备 份数据往往是无法满足还原时的需求的,所以在备份数据库时,除了要备份数据本 ...

  3. MySQL中使用innobackupex、xtrabackup进行大数据的备份和还原

    大数据量备份与还原,始终是个难点.当MYSQL超10G,用mysqldump来导出就比较慢了.在这里推荐xtrabackup,这个工具比mysqldump要快很多. 本文还参考了:http://blo ...

  4. Linux下MySQL数据库的备份与还原,mysql快速导入导出数据库实例演示,解决mysql大数据量数据库导出慢的问题

    MySQL 数据库的备份与还原 第一章:数据库的导入与导出 ① 数据库的导出 ② 大数据量下 mysqldump 的导出优化 ③ 数据库的导出 第一章:数据库的导入与导出 ① 数据库的导出 需要用到 ...

  5. MySQL使用命令备份和还原数据库

    这篇文章主要介绍了MySQL使用命令备份和还原数据库,本文使用Mysql内置命令实现备份和还原,比较简单,需要的朋友可以参考下 数据库在使用当中都会有数据库备份工作,当数据库发生严重错误无法启动,或者 ...

  6. 备份从android到ios系统,如何实现iOS和Android的数据传输?如何实现数据的备份和还原?...

    如何实现iOS和Android的数据传输?苹果和安卓如何实现数据传输? 这个问题困扰了很多的用户,今天我为大家解答一下. 一.如何实现IOS和Android数据传输? 第一步.首先我们下载安装软件&q ...

  7. MySQL 数据增量备份

    目录 MySQL 数据增量备份 binlog日志 日志概述 启用日志 自定义日志存储目录和日志文件名 手动生成新的日志文件 清理日志(删除已有的日志文件) 查看日志文件内容 使用binlog日志恢复数 ...

  8. MySQL数据的备份还原及数据修复

    在日常的生产环境中为什么要进行备份   备份可以使生产中的数据进行有效的灾难恢复:硬件故障.软件故障.自然灾害.误操作测试等数据丢失场景. 备份注意要点 能容忍最多丢失多少数据 恢复数据需要在多长时间 ...

  9. 数据库(mysql)数据的备份与还原

    (还不会创建数据表的可以看一下我的上一篇链接文章 哦) 1.数据的备份 在已输入字符的数据表内进行: 1.1 返回到mysql安装的bin路径下 输入 :mysqldump -账号 -密码 数据表名& ...

最新文章

  1. 求职者提问的问题面试官不会_如何通过三个简单的问题就不会陷入求职困境
  2. 拍照时不会摆Pose怎么办?
  3. android ios web兼容,js与android iOS 交互兼容
  4. Ajax同步和异步的区别?
  5. 2007.2.14 日程安排
  6. 关于Intel IPP的基本使用方法——参照可设置ipl库
  7. Unity有哪些让做项目事半功倍的插件值得推荐?
  8. openssl用法详解
  9. 王浩算法 c语言,基本遗传算法C语言实现.doc
  10. 搭建nginx服务器
  11. 数学建模:人口增长模型
  12. 打造健康的程序员-饮食篇
  13. numpy统计图像中某个像素值的个数
  14. iOS RN学习随笔
  15. u 只读 盘 突然_U盘变成只读,无法格式化,怎么办?
  16. NVMe1.4 Admin Command 学习(3)-- fw commit sanitize
  17. 【读书笔记】c和指针
  18. Hyperledger Fabric从源码分析交易
  19. L1-054 福到了 (15分) c++解法
  20. 什么是人力资源管理系统?hr系统功能介绍

热门文章

  1. Nature | 我的研究对后人毫无用途:21%的学术论文自发布后从未被引用
  2. cover-letter
  3. 1.7 编程基础之字符串 31 字符串p型编码 python
  4. php mysql实现下拉列表查询_php mysql如何实现通过下拉框查询显示数据库中的数据...
  5. PHP笔记-所有错误统一输出404页面(详细错误日志输出,提高安全性)
  6. Linux文档阅读笔记-cut与sort的基本用法
  7. WEB安全基础-CSRF漏洞
  8. Java高级语法笔记-字符集与中文编码
  9. oracle dg 日志手动应用,做了DG之后,日志没有被应用
  10. java简单编程_「4」Java简单编程