MySQL(四)数据备份与还原
数据备份与还原:
备份:将当前已有的数据或者记录保留
还原:将已经保留的数据恢复到对应的表中
为什么要做备份还原:
1、防止数据丢失:被盗、误操作
2、保护数据的记录
数据备份还原的方式很多:数据表备份、单表数据备份、SQL备份、增量备份
一、数据表备份:(不推荐使用)
不需要通过SQL来备份,直接进入到数据库文件夹复制对应的表结构以及数据文件,以后还原的时候,直接将备份的内容放进去即可。(这种文件备份通常适用于myisam存储引擎:直接三个文件就可以了,innodb不行,识别不了。)
有前提条件:根据不同的存储引擎有不同的区别;
存储引擎:mysql进行数据的存储方式:主要有两种:innodb和myisam(因为这两种免费)

对比myisam和innodb:数据存储方式
innodb:只有表结构,数据全部存储到ibdata1文件中。
myisam:表、数据和索引全部单独分开存储。(证明如下图)

二、单表数据备份
每次只能备份一张表,只能备份数据(表结构不可以备份)
通常使用,将表中的数据进行导出文件。
备份:
从表中选出一部分数据保存到外部文件中。
select */字段列表 into outfile 文件所在路径 from 数据源; 前提:外部文件不存在

高级备份:自己自定字段和行的处理方式
select */字段列表 into outfile 文件所在路径 fields 字段处理 lines 行处理 from 数据源; 前提:外部文件不存在
fields:字段处理
Enclosed by:字段使用什么内容包裹,默认是:空字符串
Terminated by:字段以什么结束,默认是“\t”,tab键
escaped by:特殊符号用什么方式处理,默认是“\\”,使用反斜杠转义
lines:行处理
starting by:每行以什么开始,默认是空字符串;
terminated by:每行以什么结束,默认是“\r\n”,换行符

三、数据的还原
将一个在外部保存的数据重新恢复到表中(如果表结构不存在,那么就恢复不了了)
load data infile 文件所在路径 into table 表名【(字段列表)】 fields 字段处理 lines 行处理 ——怎么备份,怎么还原。

四、SQL备份
备份的SQL语句:系统会对表结构以及数据进行处理,变成对应的SQL语句,然后进行备份,还原的时候只要执行SQL指令即可(主要就是针对表结构)
备份:mysql没有提供备份指令,但是可以利用mysql提供的软件:mysqldump.exe
mysqldump.exe也是一种客户端,需要操作服务器,必须连接认证
1、单表备份:
mysqldump/mysqldump.exe-hPup 数据库名字 【数据表名字 1【数据表名字2……】】>外部文件目录(建议使用.sql)

2、整库备份
mysqldump/mysqldump.exe-hPup 数据库名字 >外部文件目录(建议使用.sql)

五、SQL还原数据
优缺点:
优点:可以备份结构
缺点:会浪费空间,会额外的增加SQL指令。
1、使用mysql.exe 客户端还原
mysql.exe/mysql-hPup 数据库名字 < 备份文件目录

2、使用SQL指令还原
source 备份文件所在路径

六、增量备份(大的项目一般会用增量备份)
不是针对数据或者SQL指令进行备份:是针对mysql服务器的日志进行备份
增量备份:是指定时间段进行备份,备份数据不会重复,而且所有的操作都会备份。
MySQL(四)数据备份与还原的更多相关文章
- mysql之数据备份与还原
mysql数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异构系统中如Windows. #2. 逻辑备份: 备份的是建表.建库.插入等操作所执行SQL语句,适用于中 ...
- 关系型数据库MySQL(四)_备份与还原
数据库备份 备份命令:mysqldump 备份一个数据库 mysqldump -h localhost -u username -p password database_name > D:\fi ...
- MySql笔记之数据备份与还原
MySQL数据备份.还原与迁移 一.数据备份------mysqldump 1.语法: mysqldump -u user(用户名)-h host(登录用户的主机名称)-p password(登录密码 ...
- day 50 MySQL数据备份与还原(mysqldump)
MySQL数据备份与还原(mysqldump) 一 mysqldump指令实现数据备份.mysql指令实现数据还原 经常有朋友问我,DBA到底是做什么的,百科上说:数据库管理员(Databas ...
- 转 MySQL 数据备份与还原
MySQL 数据备份与还原 原贴:http://www.cnblogs.com/kissdodog/p/4174421.html 一.数据备份 1.使用mysqldump命令备份 mysqldum ...
- MYSQL数据备份与还原学习笔记
数据备份与还原 1.mysqldump 1.1 文件地址: E:\xampp\mysql\bin 文件名:mysqldump.exe CMD下进入mysqldump.exe cd E:\xampp ...
- MySQL 数据备份与还原的示例代码
MySQL 数据备份与还原的示例代码 这篇文章主要介绍了MySQL 数据备份与还原的相关知识,本文通过示例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下 一.数据备份 1.使用 ...
- MySQL 数据备份与还原 转载
MySQL 数据备份与还原 一.数据备份 1.使用mysqldump命令备份 mysqldump命令将数据库中的数据备份成一个文本文件.表的结构和表中的数据将存储在生成的文本文件中. mysqldum ...
- mysql数据库的备份和还原的总结
mysql数据库的备份和还原的总结 (来自一运维同事的总结) 1. 备份方式: 热备:数据库在线进行备份,不影响读和写的在线备份方式! 温备:数据库在线进行备份,对表备份时先锁定写操作,仅可以执行读操 ...
随机推荐
- vs code 初始化vue项目框架
1.首先安装npm组件 下载地址:https://nodejs.org/en/ 安装完 2.配置环境变量 3.验证是否成功 node -v npm -v 4.替换npm 输入npm install ...
- DOM-BOM-EVENT(6)
6.BOM 6.1.什么是BOM? BOM(Browse Object Model),浏览器对象模型,没有相关标准,是约定俗成的东西,定义了一些操作浏览器的方法和属性,大部分方法都是通过window对 ...
- 【未完待续】MVC 之HTML辅助方法
顾名思义,HTML辅助方法(HTML Helper)就是用来辅助产生HTML之用, 在开发View的时候一定会面对许多HTML标签,处理这些HTML的工作非常繁琐,为了降低View的复杂度,可以使用H ...
- 04 . kubernetes资源清单YAML入门
YAML 通过k8s操作yaml配置文件在node上创建资源,yaml配置文件就像船垛,用来操控docker这艘大船 yam是专门用来写配置文件的语言,非常简洁和强大.而实际上使用yaml配置文件创建 ...
- 线程的创建方式以及synchronize的使用
线程的两种创建方式 继承 Thread class Thr extends Thread { @Override public void run() { Thread.cur ...
- css可以修改超链接颜色吗?
超链接a标签大家都应该很熟悉,这篇文章主要的讲的是a标签的基础css样式设置,下面我们来看一下css修改超链接颜色的方法. css可以使用下面几个伪类来设置超链接: a:link :是未被访问的样式, ...
- ansible 2.7 API
# coding:utf-8 # @Time : 2019-01-14 15:22 # @Author : 小贰 # @FileName: ansible_sync_hosts.py # @funct ...
- USACO07 MAR Face The Right Way G
疫情当下,美帝又开始倒牛奶了,这一幕似曾相识啊~~~ 这个题目非常的应景,又是美国佬的奶牛 [题目地址] [一句话题意] N头牛排成一列1<=N<=5000.每头牛或者向前或者向后. 为了 ...
- [JAVA]移位运算(左移<<,右移>>和无符号右移>>>)
一.背景知识 整数在内存中是以二进制的形式存在的,而且存的是该整数的补码.最高位代表符号位,正数为0,负数为1 正数的补码是其二进制本身,负数的补码则是 符号位保持1不变,其他位按位取反再加1,+0和 ...
- java IO流 (六) 其它的流的使用
1. 标准的输入输出流:System.in:标准的输入流,默认从键盘输入System.out:标准的输出流,默认从控制台输出 修改默认的输入和输出行为:System类的setIn(InputStrea ...