MySQL 小技巧:恢复误删除的表

2024-02-03 22:12

本文主要是介绍MySQL 小技巧:恢复误删除的表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

案例说明

每天 2:30 做完全备份,早上 10:00 误删除 了表 students,10:10 才发现故障

现需要将数据库还原到 10:10 的状态,且恢复被删除的 students 表。

思路分析

  1. 停止数据库服务
  2. 将数据 还原到 2:30 的完全备份状态
  3. 再通过二进制日志还原
    1. 默认:二进制日志记录到了 10:10 你停止数据库的时间
    2. 因此:此二进制日志文件中记录着 10:00 删表的动作
    3. 所以:我们可以 将该二进制日志文件中的删表动作去除
  4. 然后基于 该去除了删除操作的二进制日志内容 将数据还原( 此期间需要关闭二进制日志记录功能 )

实际操作

前置操作

  1. 验证数据库的二进制日志功能是否开启( 且二进制日志文件存放在不同目录 )
  2. 二进制日志类型( ROW 行类型 )
0) "前置条件" ( 开启二进制日志功能 )
## 并将二进制日志文件与数据库文件分开存放
1. 创建二进制日志文件的存放目录
mkdir /mysql/data/logbin -pv
chown -R mysql:mysql /mysql/data/logbin/2. 定义二进制日志文件路径 ( 服务器选项: log-bin )
vim /etc/my.cnf
vim /etc/my.cnf.d/mysql-server.cnf      # MySQL 8.0
[mysqld]
log_bin                                 # 开启二进制日志功能 ( 必须 )
log-bin=/mysql/data/logbin/mysql-bin    # 定义二进制日志文件路径3. 重启 mariadb 服务
setenforce 0         # 关闭 SELinux ( 重要 )
systemctl restart mariadb.service
# 如重启报错 ( 可以尝试查看日志 tail -f /var/log/mysql/mysqld.log )
# 将报错信息发送至 ChatGPT 为你提供解决思路4. 验证
ll /mysql/data/logbin
cat /mysql/data/logbin/mysql-bin.index ( 该文件记录当前已有的二进制日志文件列表 )5. 验证
select @@sql_log_bin;
select @@log_bin;
select @@binlog_format;    # 查看二进制日志类型

模拟 误删数据

  1. 模拟 2:30 的完全备份
  2. 模拟 2:30 -10:00 之间的数据更新
  3. 模拟 10:00 误删除了一个重要的表
  4. 模拟 10:00 后其他表数据还在更新
  5. 模拟 10:10 发现异常

模拟 还原过程

  1. 停止数据库服务
  2. 基于 mysqlbinlog 导出二进制日志文件内容
  3. 将二进制日志文件中的删表操作去除!
  4. 准备还原数据库
    1. 启用数据库服务
    2. 登录数据库,临时关闭二进制日志功能
    3. 先还原完全备份数据
    4. 再还原二进制日志文件数据
    5. 开启二进制日志功能
  5. 验证数据库内容
// 模拟 2:30 的完全备份
// -F 选项会刷新使用一个新的二进制日志文件
[root@centos8 ~] mysqldump -uroot -p -A -F --single-transaction --master-data=2 > /backup/allbackup_`date +%F_%T`.sql[root@centos8 ~] ll /backup/-rw-r--r--. 1 root root 1235591 Feb  3 13:31 allbackup_2024-02-03_13:31:12.sql// 完全备份后的数据更新 ( 模拟 2:30 -10:00 之间的数据更新 )
use hellodb;
insert students (stuid,name,age,gender) values('50','rose',20,'f');
insert students (stuid,name,age,gender) values('60','bob',20,'m');// 模拟 10:00 误删除了一个重要的表
drop table students;// 后续其它表继续更新  ( 模拟 10:00 后其他表数据还在更新 )
use hellodb1;
insert teachers (tid,name,age,gender) values('50','wangj',20,'f');
insert teachers (tid,name,age,gender) values('60','wangjun',20,'m');MariaDB [hellodb1]> select * from teachers;
+-----+---------------+-----+--------+
| TID | Name          | Age | Gender |
+-----+---------------+-----+--------+
|   1 | Song Jiang    |  45 | M      |
|   2 | Zhang Sanfeng |  94 | M      |
|   3 | Miejue Shitai |  77 | F      |
|   4 | Lin Chaoying  |  93 | F      |
|  50 | wangj         |  20 | f      |
|  60 | wangjun       |  20 | m      |
+-----+---------------+-----+--------+
6 rows in set (0.00 sec)// 10:10 发现表删除 ( 模拟 10:10 发现异常 )
// 先停止数据库
systemctl stop mysqld// 从完全备份中, 找到二进制位置 ( 找到 2:30 - 10:10 使用的二进制日志文件名称 )
[root@centos8 ~] grep '\-\- CHANGE MASTER TO' /backup/allbackup_2024-02-03_13\:31\:12.sql
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=156;    # 得到的信息// "基于 mysqlbinlog 导出二进制日志文件内容"
[root@centos8 ~] mysqlbinlog --start-position=156 /mysql/data/logbin/mysql-bin.000003 > /backup/inc.sql// 找到误删除的语句, 从备份文件中删除此语句
// 也就是将二进制日志文件中的删表操作去除!
[root@centos8 ~] vim /backup/inc.sql
# DROP TABLE `student_info` /* generated by server */// 注: 如果文件过大, 可以使用 sed 实现    ( "重要" )
[root@centos8 ~] sed -i.bak '/^DROP TABLE/d' /backup/inc.sql// 利用完全备份和修改过的二进制日志进行还原操作
[root@centos8 ~] systemctl start mysqld      # 启用数据库服务
[root@centos8 ~] mysql -uroot -p
MariaDB [hellodb]> set sql_log_bin=0;        # 临时关闭二进制日志功能
MariaDB [hellodb]> source /backup/allbackup_2024-02-03_13:31:12.sql;
MariaDB [hellodb]> source /backup/inc.sql;
MariaDB [hellodb]> set sql_log_bin=1;        # 开启二进制日志功能// "验证数据库"
mysql -e 'show databases';
mysql -e 'select * from hellodb.students;'
mysql -e 'select * from hellodb1.teachers;'

基于如上案例,我们可以得知开启二进制日志功能的重要性以及每天做全量备份的重要性。

注意:二进制日志文件不要与数据库文件存放同一个目录。全量备份的文件也应该不存放于本机,而存放在其他主机。异机器备份。

这篇关于MySQL 小技巧:恢复误删除的表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/675576

相关文章

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南

《在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南》在SpringBoot和MyBatis项目中实现MySQL读写分离,主要有两种思路:一种是在应用层通过代码和配置手动控制... 目录如何选择实现方案核心实现:应用层手动分离实施中的关键问题与解决方案总结在Spring Boot和