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 MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

mtu设置多少网速最快? 路由器MTU设置最佳网速的技巧

《mtu设置多少网速最快?路由器MTU设置最佳网速的技巧》mtu设置多少网速最快?想要通过设置路由器mtu获得最佳网速,该怎么设置呢?下面我们就来看看路由器MTU设置最佳网速的技巧... 答:1500 MTU值指的是在网络传输中数据包的最大值,合理的设置MTU 值可以让网络更快!mtu设置可以优化不同的网

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现