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 语句未加条件导致的数据大量更新或删除的问题。希望本文能为小伙伴们提供有价值的参考,提高数据管理的安全性和可靠性!

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


在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/686967.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

医疗保健的未来——Kompas.ai如何助力精准医疗

引言 在现代医学中&#xff0c;精准医疗逐渐成为提高诊疗效果的重要手段。随着科技的进步&#xff0c;人工智能&#xff08;AI&#xff09;在医疗领域的应用越来越广泛。本文将探讨精准医疗的发展趋势&#xff0c;并介绍Kompas.ai如何通过AI技术助力精准医疗的发展。 精准医疗…

@Validated 前端表单数据校验

1. 整合 1.1 依赖引入 <dependency><groupId>org.hibernate.validator</groupId><artifactId>hibernate-validator</artifactId></dependency>1.2 控制层 /*** 新增胎架计划** param subsectionPlanVo* return*/PostMapping("/sched…

充电桩,未来出行的绿色引擎

随着新能源时代的到来&#xff0c;充电桩早已不再是一个陌生的词汇&#xff0c;它正在成为我们生活中不可或缺的一部分。 它不仅仅是一个简单的充电设备&#xff0c;更是未来出行的绿色引擎&#xff0c;驱动着我们的汽车&#xff0c;也驱动着这个时代的绿色梦想。 想象一下&am…

重庆公司记账代理,打造专业财务管理解决方案的领先企业

重庆公司记账代理&#xff0c;作为专业的财务管理服务提供商&#xff0c;我们的目标是为公司的经营管理和决策提供科学、准确的财务数据支持&#xff0c;我们通过长期的专业经验和对市场的深入理解&#xff0c;为您提供一站式的记账服务和财务咨询。 专业团队 我们拥有一支由经…

企业物料主数据管理的重要性

物料主数据包含了对所有企业所采购、生产和存储在库存中物料的集中描述。它是企业中有关物料信息的物料数据代码库。将所有的物料数据集成在单一的物料数据库中&#xff0c;消除了数据冗余的问题&#xff0c;而且不仅允许采购部门使用这些数据&#xff0c;其他应用部门也可以使…

我们如何用npm发布自己的插件包?详细的教程来了

一、什么是npm插件&#xff1f; npm&#xff08;“Node 包管理器”&#xff09;是 JavaScript 运行时 Node.js 的默认程序包管理器。npm插件是指通过npm安装的第三方包&#xff0c;可以在Node.js项目中直接使用。这些插件涵盖了各种领域&#xff0c;包括Web开发、数据测试、构建…

什么是专业的倾斜摄影轻量化?

眸瑞科技是一家专业从事自研3D可视化技术底层、提供三维模型轻量化服务的高新技术公司&#xff0c;从事该行业近10年&#xff0c;有着丰富的三维模型处理及开发经验。目前已向许多企事业单位提供过工厂厂区、城市地貌、铁路桥梁、高速公路、旅游景区等倾斜摄影模型轻量化处理、…

什么是捷云等保一体机?解密等保一体机

捷云等保一体机的优点&#xff1f; 一台设备即可满足等级保护所有安全要求&#xff0c;避免了企业购买不同厂商的安全设备的问题。 可以降低等保整改成本&#xff0c;提高整改效率&#xff0c;可以帮助企业快速实现等保合规。 2 捷云等保一体机的安全能力&#xff1f; 捷云等保…

深入了解物流运输管理系统的重要性与实践

在当今竞争激烈的商业环境中&#xff0c;物流运输管理系统正变得越发重要。随着全球化贸易的迅速发展&#xff0c;企业需要更高效、更智能的方式来管理供应链运作&#xff0c;以确保产品能够准时以最优质的方式送达客户手中。物流运输管理系统作为一个关键的工具&#xff0c;为…

高德车道级安全预警再升级 10大场景全方位守护行车安全

今日起&#xff0c;2024年高考、端午节小长假相继到来&#xff0c;正值新一波出行高峰到来&#xff0c;高德地图车道级安全预警功能再次升级。升级后的车道级安全预警功能覆盖了10大安全风险较高的行车场景&#xff0c;全方位、超视距地为用户实时探测、预警行车风险&#xff0…

工厂生产计划难以执行的真正原因及对策

在制造业中&#xff0c;生产计划的执行对于企业的运营至关重要。然而&#xff0c;许多工厂在生产计划执行过程中面临着诸多挑战&#xff0c;尤其是物料齐套率低的问题。本文将探讨工厂生产计划难以执行的真正原因&#xff0c;并提出相应的解决对策。 一、生产计划难以执行的真…

005.FashionMNIST数据集简介

一、FashionMNIST数据集简介 FashionMNIST数据集&#xff0c;是一款作为经典的MNIST数据集的现代替代品的数据集&#xff0c;用来做衣物分类问题&#xff0c;由Zalando&#xff08;一家德国的在线时尚零售商&#xff09;发布。 该数据集含有10种类别&#xff0c;共70000个灰度图…

[Cesium学习]

Popup弹窗 Cesium点位弹窗_cesium popup弹窗-CSDN博客 Cesium构造popup弹窗函数_cesium popup-CSDN博客 开发之家 - Cesium构造popup弹窗函数 GitHub - cesium-plugin/cesium-popup-es6: 气泡弹窗 热力图分析 // 创建Cesium Viewer实例 const viewer new Cesium.Viewer(c…

java:reactor的Mono和Reactor的简单例子

【pom.xml】 <dependency><groupId>io.projectreactor</groupId><artifactId>reactor-core</artifactId><version>3.3.17.RELEASE</version> </dependency>【MyReactorTest2.java】 package com.chz.myReactor;import react…

擎创动态 | 擎创科技受邀参与电信数智“走进地市“专项行动启动会

为贯彻落实电信集团公司云改数转战略&#xff0c;切实推进数智公司"三化"战略落地&#xff0c;强化全国数智体系协同建设&#xff0c;5月24日由中电信数智科技有限公司&#xff08;以下简称“电信数智”&#xff09;、中国电信党校&#xff08;以下简称“人才发展中心…

SITNE24V2BNQ-3/TR一种瞬态电压抑制器,对标PESD1CAN

SITNE24V2BNQ是一种瞬态电压抑制器&#xff0c;设计用于保护两个汽车控制器区域 网络(CAN)母线不受ESD等瞬变造成的损坏。 SITNE24V2BNQ采用SOT-23封装。标准产品不含铅和卤素。 产品参数 方向&#xff1a;双向通道数&#xff1a;2VRWM(V)(Max)&#xff1a;24IPP8/20μS(A)(M…

风丘新加坡全资子公司正式成立!

在风丘科技&#xff08;WINDHILL&#xff09;成立20周年之际&#xff0c;风丘全资子公司——WINDHILL TECHNOLOGIES PTE. LTD.于2024年3月初正式在新加坡注册成立。 随着出海4.0时代的到来&#xff0c;为更快地响应海外区域客户的需求&#xff0c;风丘加大了区域市场的投入&…

stm32中如何实现EXTI线 0 ~ 15与对应IO口的配置呢?

STM32的EXTI控制器支持19 个外部中断/ 事件请求。每个中断设有状态位&#xff0c;每个中断/ 事件都有独立的触发和屏蔽设置。 STM32的19个外部中断对应着19路中断线&#xff0c;分别是EXTI_Line0-EXTI_Line18&#xff1a; 线0~15&#xff1a;对应外部 IO口的输入中断。 线16&…

Angular17版本集成Quill富文本编辑器

Angular17版本集成Quill富文本编辑器 前言:网上找了好多富文本资源,对应Angular17版本的且兼容的太少了,且找到不到对应的版本 自己就去网上找个兼容的免费的富文本组件 1.兼容Angular17版本的quill包 "types/quill": "^1.3.10","ngx-quill": …

攻防世界testre做法(考点:base58)

在做这道题目之前&#xff0c;我们先来简单了解一下base64加密和base58加密&#xff0c;先来说一些预备知识&#xff0c;bit为1个位&#xff0c;即一个0或1&#xff0c;八个位组成一个字节&#xff0c;即八个二进制数。 base64编码原理&#xff1a;1&#xff0c;在使用base64加…