MySQL数据库数据恢复方案应对没有where误操作导致的大量数据更新或删除

本文主要是介绍MySQL数据库数据恢复方案应对没有where误操作导致的大量数据更新或删除,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~
🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志
🎐 个人CSND主页——Micro麦可乐的博客
🐥《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程,入门到实战
🌺《RabbitMQ》专栏主要介绍使用JAVA开发RabbitMQ的系列教程,从基础知识到项目实战
🌸《设计模式》专栏以实际的生活场景为案例进行讲解,让大家对设计模式有一个更清晰的理解
💕《Jenkins实战》专栏主要介绍Jenkins+Docker的实战教程,让你快速掌握项目CI/CD,是2024年最新的实战教程
🌞《Spring Boot》专栏主要介绍我们日常工作项目中经常应用到的功能以及技巧,代码样例完整
如果文章能够给大家带来一定的帮助!欢迎关注、评论互动~

MySQL数据库数据恢复方案应对误操作导致的大量数据更新或删除

  • 你是否也遇到这种问题?
  • 前提条件
  • 开始演示
    • 创建测试数据
    • 模拟删除
    • 获取binlog
    • 开始恢复
      • 情况一
      • 情况二
    • 验证结果
  • 结语

你是否也遇到这种问题?

平时我们在系统开发过程中操作数据库的时候,在执行 UpdateDelete 语句时因为自己的疏忽忘记传递 Where 条件,导致数据库中的数据大量的被更新或删除,你是不是准备跑路?

不要慌,借助 SQL 正是当前CSDN热门话题的机会,博主今天来详细讲解如何应对这种情况并提供数据恢复方案。

前提条件

如果你公司中有专门运维人员或专职的 DBA(全称Database Administrator),又或者你就是公司里那个从前端到后端再到运维都是你负责的全能型人才,在安装MySQL 数据库的时候一般都会开启binlog日志。

首先本次博主以 MySQL 数据库使用的是MySQL8,且开启了binlog,执行以下命令查看是否开启了binlog

SHOW VARIABLES = 'log_bin';

输出结果如果是ON,则代表已经开启
在这里插入图片描述

binlog作用

binlog 一般是做为数据库主从同步时候从库的数据的来源,另外一方面就可以用于恢复数据。
针对 MYSQL主从同步 可以参考博主的这篇教程:Docker上实现MYSQL实现主从复制

本次我们就是利用binlog来实现恢复数据!

开始演示

创建测试数据

首先我们创建 recovery-test 数据库,并创建一个 student 学生表,并插入测试数据

CREATE TABLE `student` (`id` int NOT NULL AUTO_INCREMENT COMMENT '学生ID',`name` varchar(50) NOT NULL COMMENT '学生姓名',`gender` varchar(10) NOT NULL COMMENT '学生性别',`birthday` date NOT NULL COMMENT '学生生日',`address` varchar(100) NOT NULL COMMENT '学生住址',`phone` varchar(20) NOT NULL COMMENT '学生联系方式',PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='学生信息表';INSERT INTO `student` VALUES (1, '小明', '男', '2023-06-16', '广州', '13700137000');
INSERT INTO `student` VALUES (2, '小羊', '女', '2023-06-16', '广州', '13800126000');

模拟删除

模拟我们因为疏忽没有拼接 WHERE 条件的情况

DELETE FROM student

获取binlog

如果你不清楚binlog的存储位置可以执行

SHOW VARIABLES LIKE 'log_bin_basename';

可以看到binlog的命名以及前缀的路径
在这里插入图片描述
以博主mac系统进入对应目录查看,可以看到binlog的相关文件,可以根据时间获取binlog当前的文件名
在这里插入图片描述
或者你也可以执行下面的语句,获取当前当前binlog文件名

show master status;

开始恢复

在已经确认了 binlog 文件路径以及当前 binlog 文件名后,你可能会有以下两种情况:

情况一

如果你明确误操作的时间,可以执行根据删除前的时间来恢复数据,

mysqlbinlog --start-datetime="开始时间" \
--stop-datetime="结束时间" \--database="recovery-test" \/usr/local/var/mysql/binlog.016924 > binlog_before_delete.sql

情况二

如果你已经忘记了误操作的时间,那么就可以使用查询指定 SQL 的语句来获取语句执行在日志中的 position

mysqlbinlog --no-defaults -vv \/usr/local/var/mysql/binlog.016924 \--database="recovery-test" | grep -iE "(update | delete)";

其中 grep -iE "(update | delete)" 你可以替换匹配你的误操作语句,由于是新表且只删除了一次,这里博主就模糊匹配 update 或 delete

最终会获得操作语句的position值,如博主的输出如下
在这里插入图片描述

提示
#240607 就是博主获取删除时候的 position 值
如果你删除非当前当前binlog文件 ,可以依次查询其它 binlog 文件

最后根据 position 的值执行

mysqlbinlog --start-position=240600 \
--stop-position=240607 \--database="recovery-test" \/usr/local/var/mysql/binlog.016924 > binlog_before_delete.sql

最后执行还原操作,大家自行替换自己对应参数即可

mysql -u root -p recovery-test  < binlog_before_delete.sql

验证结果

恢复数据后,必须进行数据验证,确保数据的完整性和正确性。

结语

日常工作中处理出了使用 mysqldump 来定时备份数据用以还原外,你还可以通过以上述讲解步骤,有效应对由于 UPDATEDELETE 语句未加条件导致的数据大量更新或删除的问题。希望本文能为小伙伴们提供有价值的参考,提高数据管理的安全性和可靠性!

如果你在学习过程中如有疑问欢迎留言探讨,博主将在闲暇时间及时进行答复!如果本文有帮助到你,希望一键三连多多支持博主!


在这里插入图片描述

这篇关于MySQL数据库数据恢复方案应对没有where误操作导致的大量数据更新或删除的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

豆包 MarsCode 不允许你还没有女朋友

在这个喧嚣的世界里,爱意需要被温柔地唤醒。为心爱的她制作每日一句小工具,就像是一场永不落幕的浪漫仪式,每天都在她的心田播撒爱的种子,让她的每一天都充满甜蜜与期待。 背景 在这个瞬息万变的时代,我们都在寻找那些能让我们慢下来,感受生活美好的瞬间。为了让这份浪漫持久而深刻,我们决定为女朋友定制一个每日一句小工具。这个工具会在她意想不到的时刻,为她呈现一句充满爱意的话语,让她的每一天都充满惊喜和感动

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo