阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL备份与恢复详述

188次阅读
没有评论

共计 14254 个字符,预计需要花费 36 分钟才能阅读完成。

一、MySQL 完全备份与恢复

备份的主要目的是灾难恢复,备份还可以测试应用、回滚数据修改、查询历史数据、审计等。

1、数据备份的重要性

在企业中数据的价值至关重要,数据保障了企业业务的正常运行。因此,数据的安全性及数据的可靠性是运维的重中之重,任何数据的丢失都可能对企业产生严重的后果。通常情况下造成数据丢失的原因如下几种:

程序错误
人为操作错误
运算错误
磁盘故障
灾难(火灾、地震)和盗窃
三、常见的备份方法

二、数据库备份类型

1、从物理与逻辑的角度:

数据库备份可以分为物理备份和逻辑备份。物理备份是对数据库操作系统的物理文件(如数据文件、日志文件等)的备份。这种类型的备份适用于在出现问题时需要快速恢复的大型重要数据库。

物理备份又可以分为冷备份(脱机备份)、热备份(联机备份)和温备份。

  • 冷备份:在数据库关闭状态下进行备份操作;
  • 热备份:在数据库处于运行状态时进行备份操作,该备份方法依赖数据库的日志文件;

  • 温备份:数据库锁定表格(不可写入,但可读取)的状态下进行备份;

逻辑备份是对数据库逻辑组件(如表等数据库对象)的备份,表示为逻辑数据库结构(create database、create table 语句)和内容(insert 语句或分隔文本文件)的信息。这种类型的备份使用于可以编辑数据值或表结构较小的数据量,或者在不同的机器体系上重新创建数据。

2、从数据库的备份策略角度:

从数据库的备份策略角度,数据库的备份可分为完全备份、差异备份和增量备份。其中呢,完整备份是实现差异、增量备份的基础。

  • 完整备份:每次对数据进行完整的备份,即对整个数据库的备份。备份与恢复的操作非常简单,但是数据存在大量的重复,会占用大量的磁盘空间,备份的时间也很长。

  • 差异备份:备份那些自从上次完全备份之后被修改过的所有文件,备份的时间点是从上次完整备份起,备份数据会越来越大,恢复数据时,只需恢复上次的完全备份和最近的一次差异备份。

  • 增量备份:只有在那些在上次完全备份或增量备份后被修改的文件才会被备份,以上次完整备份或上次增量备份的时间为时间点,仅仅备份这之间的数据变化,因而备份的数据量也小,占用空间小,备份速度快,但恢复时,需要从上一次的完整备份开始到最后一次增量备份之间的所有增量依次恢复,一旦中间的数据发生损坏,将导致数据的丢失。

三、常见的备份方法

MySQL 数据库的备份可以采用很多种方式,如直接打包数据库文件(物理冷备份)、专用备份工具(mysqldump)、二进制日志增量备份、第三方工具备份等。

1、物理冷备份

物理冷备份时需要在数据库处于关闭状态下,能够较好地保证数据库的完整性。物理冷备份一般用于非核心业务,这类业务一般都允许中断,物理冷备份的特点就是速度快,恢复时也是最为简单。

2、专用备份工具 mysqldump 或 mysqlhotcopy

mysqldump 程序和 mysqlhotcopy 都可以做备份。mysqqldump 是客户端常用逻辑备份程序,能够产生一组被执行以再现原始数据库对象定义和表数据的 SQL 语句。它可以转储一个到多个 MySQL 数据库,对其进行备份或传输到远程 SQL 服务器。mysqldump 更为通用,因为它可以备份各种表。mysqlhotcopy 仅适用于某些存储引擎。

3、通过启用二进制日志进行增量备份

MySQL 支持增量备份,进行增量备份时必须启用二进制日志。二进制日志文件为用户提供复制,对执行备份点后进行的数据库更改所需的信息进行恢复。如果进行增量备份(包含自上次完全备份或增量备份以来发生的数据修改),需要刷新二进制日志。

四、数据库完全备份操作

1、备份前准备

[root@CentOS01 ~]# mysqladmin -u root password  <!--mysql 数据库设置密码 -->
New password:             <!-- 输入密码 -->
Confirm new password:        <!-- 确认密码 -->
[root@centos01 ~]# mysql -uroot -ppwd@123    <!-- 登录 MySQL 数据库 -->
mysql> create database benet;        <!-- 创建 benet 数据库 -->
mysql> use benet;             <!-- 切换到 benet 数据库创建表 -->
mysql> create table 一班学生成绩 (姓名 char(3), 班级 char(5), 学号 char(8), 语文 char(3),
数学 char(3), 英语 char(3), 理综 char(3), primary key (学号));  
<!-- 创建表,表名字为一班学生成绩,第一列名字是姓名,第二列名字为班级,第三列名字
为学号,第四列名字为语文,第五列名字为数学,第六列名字为英语,第七列名字为理综 -->
mysql> insert into 一班学生成绩 value ('张三','一班','20170822','110','105','92','235');  
                   <!-- 表中插入数据 -->
mysql>  insert into 一班学生成绩 value ('李四','一班','20170820','95','115','110','260');  
                   <!-- 表中插入数据 -->
mysql> insert into 一班学生成绩 value ('王五','一班','20170818','95','103','108','270');  
                   <!-- 表中插入数据 -->
mysql> insert into 一班学生成绩 value ('赵六','一班','20170816','100','109','112','265'); 
                   <!-- 表中插入数据 -->
mysql> select * from benet. 一班学生成绩;   <!-- 查看一班学生成绩表中所有数据 -->

MySQL 备份与恢复详述

2、物理冷备份与恢复

物理冷备份一般用 tar 命令直接打包数据库文件夹,而在进行备份之前需要使用“systemctl stop mysqld”命令关闭 mysql 服务。

1)备份数据库

创建一个 /bak 目录作为备份数据存储路径,使用 tar 创建备份文件。整个数据库文件夹备份属于完全备份。

[root@centos01 ~]# systemctl stop mysqld  <!-- 停止 mysql 服务 -->
[root@centos01 ~]mkdir /bak/   <!-- 创建存储备份目录 -->
[root@centos01 ~]# tar zcf /bak/mysql_all-$(date +%F).mysql.gz /usr/local/mysql/data/    
                 <!-- 直接 tar 打包数据库文件 -->
[root@centos01 ~]# ls /bak/     <!-- 查看备份的数据 -->
-rw-r--r-- 1 root root 766598 10 月 31 03:57 /bak/mysql_all-2019-10-31.mysql.gz

2)恢复数据库

[root@centos01 ~]mkdir test  <!-- 创建恢复数据目录 -->
[root@centos01 ~]# tar zxvf /bak/mysql_all-2019-10-31.mysql.gz  -C ./test/   
                <!-- 解压缩备份数据到恢复目录 -->
[root@centos01 data]# cd /usr/local/mysql/data/  <!-- 进入数据原始位置 -->
[root@centos01 data]# rm -rf ./*  <!-- 删除数据 -->
[root@centos01 ~]# cd ./test/usr/local/mysql/data/  <!-- 切换到恢复目录 -->
[root@centos01 date]#mv ./* /usr/local/mysql/data/    <!-- 将恢复目录数据恢复到原始位置 -->
[root@centos01 ~]# systemctl start mysqld  <!-- 启动 mysql 服务 -->

3、mysqldump 备份与恢复

通过 mysqldump 命令可以将指定的库、表或全部的库导出为 SQL 脚本,便于该命令在不同版本的 MySQL 服务器上使用。

1)备份恢复所有数据库

[root@centos01 ~]# mysqldump -uroot -ppwd@123 --opt --all-databases > ./test/benet_databases.sql     <!-- 备份所有库,opt 选项是优化执行速度 -->
[root@centos01 ~]# mysql -uroot -p     <!-- 登录数据库 -->
Enter password:          <!-- 数据密码 -->
mysql> show databases;         <!-- 查看所有数据库 -->
+--------------------+
| Database           |
+--------------------+
| information_schema |
| benet              |
| mysql              |
| performance_schema |
| test               |
+--------------------+
mysql> drop database benet;  <!-- 删除 benet 数据库 -->
mysql> show databases;      <!-- 查看数据库是否删除 -->
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
[root@centos01 ~]# mysql -u root -p < ./test/benet_databases.sql 
Enter password:     <!-- 恢复所有数据库 -->
mysql> show databases;     <!-- 查看数据库是否恢复 -->
+--------------------+
| Database           |
+--------------------+
| information_schema |
| benet              |
| mysql              |
| performance_schema |
| test               |
+--------------------+
mysql> source ./test/benet_databases.sql 
             <!-- 也可以通过这种方法恢复误删除的数据库 -->

2)备份恢复数据库中的表

[root@centos01 ~]# mysqldump -uroo t -ppwd@123 benet 一班学生成绩 > ./test/benet_一班学生成绩.sql   
                         <!-- 备份数据库下的表 -->
[root@centos01 ~]# mysql -uroot -p       <!-- 登录数据库 -->
Enter password:        <!-- 输入密码 -->
mysql> use benet;      <!-- 切换到 benet 数据库 -->
mysql> drop table 一班学生成绩;      <!-- 删除一班学生成绩表 -->
mysql> show tables;        <!-- 查看表是否删除 --> 
Empty set (0.00 sec)
[root@centos01 ~]# mysql -uroot -p benet < ./test/benet_一班学生成绩.sql  
                           <!-- 恢复误删除的表 -->
[root@centos01 ~]# mysql -uroot -p    <!-- 登录数据库 -->
Enter password:           <!-- 输入密码 -->
mysql> use benet;         <!-- 切换到 benet 数据库 -->
Database changed
mysql> show tables;    <!-- 查看误删除的表是否恢复 -->
+--------------------+
| Tables_in_benet    |
+--------------------+
| 一班学生成绩       |
+--------------------+
1 row in set (0.00 sec)

五、MySQL 增量备份与恢复

使用 mysqldump 进行完全备份,备份的数据中有重复数据,备份时间与恢复时间过长。而增量备份就是备份自上一次备份之后增加或改变的文件或内容。

1、MySQL 增量备份的特点

与完全备份不同,增量备份没有重复数据,备份量不大,时间短;但其恢复麻烦,需要上次完全备份及完全备份之后所有的增量备份才能恢复,而且要对所有增量备份进行逐个反推恢复。可以通过 MySQL 提供的二进制日志间接实现增量备份。

2、MySQL 增量备份与恢复

二进制日志保存了所有更新或���可能更新数据库的操作。二进制日志在启动 MySQL 服务器后开始记录,并在文件达到二进制日志所设置的最大值或者接收到 flush logs 命令后重新创建新的日志文件,生成二进制文件序列,并及时把这些日志保存到安全的存储位置,即可完成一个时间段的增量备份。
要进行 MySQL 的增量备份,首先要开启二进制日志功能,开启 MySQL 的二进制日志功能的实现方法如下:

[root@centos01 ~]# vim /etc/my.cnf       <!-- 进入 MySQL 配置文件 -->
.......    <!-- 此处省略部分内容 -->
log-bin=mysql-bin      <!-- 开启二进制日志功能 -->
[root@centos01 ~]# systemctl restart mysqld   <!-- 重启 MySQL 服务 -->
[root@centos01 ~]# ls -l /usr/local/mysql/data/
......             <!-- 此处省略部分内容 -->
-rw-rw---- 1 mysql mysql    27299 10 月 31 00:00 mysql-bin.000001
-rw-rw---- 1 mysql mysql  1031892 10 月 31 00:00 mysql-bin.000002
-rw-rw---- 1 mysql mysql     1574 10 月 31 14:13 mysql-bin.000003
-rw-rw---- 1 mysql mysql   507535 11 月  1 09:37 mysql-bin.000004
-rw-rw---- 1 mysql mysql   507229 11 月  1 09:40 mysql-bin.000005
-rw-rw---- 1 mysql mysql       95 11 月  1 09:37 mysql-bin.index
drwx------ 2 mysql mysql     4096 10 月 31 00:00 performance_schema
drwxr-xr-x 2 mysql mysql       20 10 月 30 23:56 test

1)增量备份

[root@centos01 ~]# mysqladmin -uroot -ppwd@123 flush-logs  <!-- 刷新二进制日志 -->
[root@centos01 ~]# ls -l /usr/local/mysql/data/     <!-- 查看二进制日志文件 -->
......   <!-- 此处省略部分内容 -->
-rw-rw---- 1 mysql mysql    27299 10 月 31 00:00 mysql-bin.000001
-rw-rw---- 1 mysql mysql  1031892 10 月 31 00:00 mysql-bin.000002
-rw-rw---- 1 mysql mysql     1574 10 月 31 14:13 mysql-bin.000003
-rw-rw---- 1 mysql mysql   507535 11 月  1 09:37 mysql-bin.000004
-rw-rw---- 1 mysql mysql   507272 11 月  1 09:49 mysql-bin.000005
-rw-rw---- 1 mysql mysql      107 11 月  1 09:49 mysql-bin.000006
-rw-rw---- 1 mysql mysql      114 11 月  1 09:49 mysql-bin.index
drwx------ 2 mysql mysql     4096 10 月 31 00:00 performance_schema
drwxr-xr-x 2 mysql mysql       20 10 月 30 23:56 test
[root@centos01 ~]# mysql -uroot -ppwd@123  <!-- 登录 mysql 数据库 -->
mysql> use benet;           <!-- 切换到 benet 数据库 -->
mysql> insert into 一班学生成绩 value ('李宁','二班','20170824','92','98','105','235');            
                    <!-- 录入新的数据 -->
Query OK, 1 row affected (0.01 sec)
mysql> insert into 一班学生成绩 value ('陈铭','二班','20170826','111','107','96','204');           
                    <!-- 录入新的数据 -->
Query OK, 1 row affected (0.00 sec)
mysql> select *from 一班学生成绩;    <!-- 查看新数据是否录入 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
| 李宁   | 二班   | 20170824 | 92     | 98     | 105    | 235    |
| 陈铭   | 二班   | 20170826 | 111    | 107    | 96     | 204    |
+--------+--------+----------+--------+--------+--------+--------+
6 rows in set (0.00 sec)
[root@centos01 ~]# mysqladmin -uroot -ppwd@123 flush-logs  
                          <!-- 刷新二进制日志 -->
[root@centos01 ~]# ls -l /usr/local/mysql/data/    
                               <!-- 查看二进制日志文件 -->
......          <!-- 此处省略部分内容 -->
-rw-rw---- 1 mysql mysql    27299 10 月 31 00:00 mysql-bin.000001
-rw-rw---- 1 mysql mysql  1031892 10 月 31 00:00 mysql-bin.000002
-rw-rw---- 1 mysql mysql     1574 10 月 31 14:13 mysql-bin.000003
-rw-rw---- 1 mysql mysql   507535 11 月  1 09:37 mysql-bin.000004
-rw-rw---- 1 mysql mysql   507272 11 月  1 09:49 mysql-bin.000005
-rw-rw---- 1 mysql mysql      649 11 月  1 09:58 mysql-bin.000006
-rw-rw---- 1 mysql mysql      107 11 月  1 09:58 mysql-bin.000007
-rw-rw---- 1 mysql mysql      133 11 月  1 09:58 mysql-bin.index
drwx------ 2 mysql mysql     4096 10 月 31 00:00 performance_schema
drwxr-xr-x 2 mysql mysql       20 10 月 30 23:56 test
[root@centos01 ~]# cp /usr/local/mysql/data/mysql-bin.000006 /root/test/   
                            <!-- 复制二进制日志 -->

2)模拟误操作删除一班学生成绩表

[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'drop table benet. 一班学生成绩;'       
                    <!-- 删除一班学生成绩表 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'   
                      <!-- 查看表是否删除 -->
ERROR 1146 (42S02) at line 1: Table 'benet. 一班学生成绩' doesn't exist

3)恢复误删除的表

[root@centos01 ~]# mysql -uroot -ppwd@123 < ./test/benet_databases.sql   
                     <!-- 恢复完全备份 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'        
                        <!-- 查看完全备份数据是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
+--------+--------+----------+--------+--------+--------+--------+
[root@centos01 ~]# mysqlbinlog --no-defaults /root/test/mysql-bin.000006 |mysql -u root -p 
                   <!-- 恢复增量备份 -->
Enter password:       <!-- 输入密码 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'      
                     <!-- 查看增量恢复数据是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
| 李宁   | 二班   | 20170824 | 92     | 98     | 105    | 235    |
| 陈铭   | 二班   | 20170826 | 111    | 107    | 96     | 204    |
+--------+--------+----------+--------+--------+--------+--------+

3、基于位置恢复

[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'drop table benet. 一班学生成绩;'   
                <!-- 删除一班学生成绩表 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'  
                 <!-- 查看表是否删除 -->
ERROR 1146 (42S02) at line 1: Table 'benet. 一班学生成绩' doesn't exist
[root@centos01 ~]# mysql -uroot -ppwd@123 < ./test/benet_databases.sql     
               <!-- 恢复完全备份 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'     
               <!-- 查看完全备份是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
+--------+--------+----------+--------+--------+--------+--------+
[root@centos01 ~]# mysqlbinlog --no-defaults /root/test/mysql-bin.000006       
                <!-- 查看二进制日志文件确认恢复的位置或时间点 -->
......         <!-- 此处省略部分内容 -->
# at 176                  <!--at 就是我们称之为操作 ID,下面紧跟的是时间标记 -->
#191101  9:55:33 server id 1  end_log_pos 329   Query   thread_id=9 exec_time=0 error_code=0
use benet/*!*/;
SET TIMESTAMP=1572573333/*!*/;
insert into 一班学生成绩 value ('李宁','二班','20170824','92','98','105','235')
/*!*/;
# at 329
#191101  9:55:33 server id 1  end_log_pos 356   Xid = 278
COMMIT/*!*/;
# at 356
#191101  9:55:43 server id 1  end_log_pos 425   Query   thread_id=9 exec_time=0 error_code=0
SET TIMESTAMP=1572573343/*!*/;
BEGIN
/*!*/;
# at 425       <!--at 就是我们称之为操作 ID,下面紧跟的是时间标记 -->
#191101  9:55:43 server id 1  end_log_pos 579   Query   thread_id=9 exec_time=0 error_code=0
SET TIMESTAMP=1572573343/*!*/;
insert into 一班学生成绩 value ('陈铭','二班','20170826','111','107','96','204')
/*!*/;
[root@centos01 ~]# mysqlbinlog --no-defaults --stop-position='425' /root/test/mysql-bin.000006 |mysql -uroot -p       <!-- 基于 ID 恢复增量备份 -->
Enter password:       <!-- 输入密码 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'    
               <!-- 查看数据是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
| 李宁   | 二班   | 20170824 | 92     | 98     | 105    | 235    |
+--------+--------+----------+--------+--------+--------+--------+

上述命令中“–stop-position”指定的是停止的位置,如果仅恢复“陈铭”的信息,跳过“李宁”的信息恢复,可以使用“–start-position”选项指定开始恢复数据的位置。这时所恢复的数据是从指定位置开始直到二进制日志文件的最后。

[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'drop table benet. 一班学生成绩;'    
                   <!-- 删除一班学生成绩表 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'  
                  <!-- 查看表是否删除 -->
ERROR 1146 (42S02) at line 1: Table 'benet. 一班学生成绩' doesn't exist
[root@centos01 ~]# mysql -uroot -ppwd@123 < ./test/benet_databases.sql      
                          <!-- 恢复完全备份 -->
[root@centos01 ~]# mysqlbinlog --no-defaults --start-position='425' /root/test/mysql-bin.000006 |mysql -uroot -p       <!-- 基于 ID 恢复增量备份 -->
Enter password:        <!-- 输入密码 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'    
                 <!-- 查看数据是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
| 陈铭   | 二班   | 20170826 | 111    | 107    | 96     | 204    |
+--------+--------+----------+--------+--------+--------+--------+

4、基于时间点恢复

基于时间点恢复数据所使用的选项是“–stop-datetime”,指定的时间同样也是查询二进制日志所得。执行一下操作可以实现仅恢复到 9:55:43 之前的数据,即不恢复“陈铭”的信息。

[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'drop table benet. 一班学生成绩;' 
                      <!-- 删除一班学生成绩表 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'  
                 <!-- 查看表是否删除 -->
ERROR 1146 (42S02) at line 1: Table 'benet. 一班学生成绩' doesn't exist
[root@centos01 ~]# mysql -uroot -ppwd@123 < ./test/benet_databases.sql    
                   <!-- 恢复完全备份 -->
[root@centos01 ~]# mysqlbinlog --no-defaults --stop-datetime='2019-11-01  9:55:43' /root/test/mysql-bin.000006 |mysql -uroot -p     
                         <!-- 基于时间点恢复增量备份 -->
Enter password:       <!-- 输入密码 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'    
                           <!-- 查看数据是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
| 李宁   | 二班   | 20170824 | 92     | 98     | 105    | 235    |
+--------+--------+----------+--------+--------+--------+--------+

执行以下操作可以实现仅恢复“陈铭”的信息,跳过“李宁”的信息恢复

[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'drop table benet. 一班学生成绩;'   
                      <!-- 删除一班学生成绩表 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'    
                 <!-- 查看表是否删除 -->
ERROR 1146 (42S02) at line 1: Table 'benet. 一班学生成绩' doesn't exist
[root@centos01 ~]# mysql -uroot -ppwd@123 < ./test/benet_databases.sql     
                         <!-- 恢复完全备份 -->
[root@centos01 ~]# mysqlbinlog --no-defaults --start-datetime='2019-11-01 9:55:43'
/root/test/mysql-bin.000006 |mysql -uroot -p      
                      <!-- 基于时间恢复增量备份 -->
Enter password:        <!-- 输入密码 -->
[root@centos01 ~]# mysql -uroot -ppwd@123 -e 'select * from benet. 一班学生成绩;'    
                       <!-- 查看数据是否恢复 -->
+--------+--------+----------+--------+--------+--------+--------+
| 姓名   | 班级   | 学号     | 语文   | 数学   | 英语   | 理综   |
+--------+--------+----------+--------+--------+--------+--------+
| 赵六   | 一班   | 20170816 | 100    | 109    | 112    | 265    |
| 王五   | 一班   | 20170818 | 95     | 103    | 108    | 270    |
| 李四   | 一班   | 20170820 | 95     | 115    | 110    | 260    |
| 张三   | 一班   | 20170822 | 110    | 105    | 92     | 235    |
| 陈铭   | 二班   | 20170826 | 111    | 107    | 96     | 204    |
+--------+--------+----------+--------+--------+--------+--------+

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计14254字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中