MySQL恢复不小心误删的数据记录(binlog)-生产实操

news/2024/5/18 21:08:48/文章来源:https://blog.csdn.net/wscwsc58888/article/details/133981431

同事操作删除生产数据时,未及时备份导致误删除部份数据。现通过mysql的binlog日志回滚数据。

1.由于我们第一时间找到相应的操作时间的大概在12点~13点之间操作删除了product和product_item表的部份数据。因此我们只要找到这期间的binlog文件就行了,

脚本为:delete from product_item  where shop_id = '1630131736490098689';

             delete from product  where shop_id = '1630131736490098689';

cd /var/lib/mysql
ll

(该图为后面载图的)

2.先cp到其它目录去操作。千万不要在原目录操作!!!!
cd /mnt
mkdir  mysqlbak003217
cp /var/lib/mysql/binlog.* /mnt/mysqlbak003217/

3.通过分析找到对应的binlog文件(通过时间缩小范围)并通过mysqlbinlog 命令转为sql文件

binlog.003216,binlog.003217,binlog.003218三个文件中找

mysqlbinlog --base64-output=decode-rows -v binlog.003216 --result-file=mysql-bin-sql-003216.sql  
mysqlbinlog --base64-output=decode-rows -v binlog.003218 --result-file=mysql-bin-sql-003218.sql     
mysqlbinlog --base64-output=decode-rows -v binlog.003217 --result-file=mysql-bin-sql-003217.sql 

4找到你误删的数据

一般来说你误删的数据会大致记下来一个标识。我这里是shop_id。记得被删除的数据的是多少,那么我们就可以模糊搜索该条件:

grep '1630131736490098689' mysql-bin-sql-003217.sql  -C 200或

grep '1630131736490098689' mysql-bin-sql-003217.sql  -C 200 --> 1630131736490098689.sql 输出文件查看下delete from 的脚本。

 

确认是 mysql-bin-sql-003217.sql文件

5.通过linux命令,查找需的数据,成为需要的数据(#每完成一份正确的数据,都及时备份下文件。以免操作错误重头开始

grep 'DELETE FROM' mysql-bin-sql-003217.sql  -C 200 --> delete20231021.sql#每完成一份正确的数据,都及时备份下。以免操作错误重头开始
cp delete20231021.sql delete20231021.sql.bak#拆分两个表的操作数据SQL(过程是通过反复操作及分析的结果)
grep 'DELETE FROM `lirimall_server`.`product_item`' mysql-bin-sql-003217.sql  -C 200 --> deleteproduct_item20231021.sqlgrep 'DELETE FROM `lirimall_server`.`product`' mysql-bin-sql-003217.sql  -C 200 --> deleteproduct20231021.sql
6。分别处理两个操作数据的文件

删除无效数据,

#包括特殊字符"",#,|"这些的处理,这个只能通过SQL工具测试后有异常再更新文件

mkdir product_itme
mkdir product
cp deleteproduct20231021.sql ./product
cp deleteproduct_item20231021.sql ./product_item/cd product#备份数据
cp deleteproduct20231021.sql deleteproduct20231021.sql.bak#删除无用的数据,特殊字符的数据
vi deleteproduct20231021.sql
#文件命令:
#显示行数
:set nu
#删除1-200行的数据
:1,200d
#删除336581~336938d行的数据
:336581,336938d
#搜索“# at”的数据
/# at
#到文件的结尾处查看下
:$#包括特殊字符"",#,|"这些的处理,这个只能通过SQL工具测试后有异常再更新

7.通过linux的sed 命令把delete删除语句替换为insert into语句(有问题可反复执行-一定要备份文件)-
sed -i 's/^### //g' deleteproduct20231021.sql
sed -i "s/^DELETE FROM/INSERT INTO/g" deleteproduct20231021.sql
sed -i "s/^WHERE/VALUES(/g" deleteproduct20231021.sql
sed -i '/INSERT INTO/i );' deleteproduct20231021.sqlcat deleteproduct20231021.sql  | awk -F"=|" '{if($0 ~ /^INSERT|^VALUES|^);/){print $0;}else{printf $2",";};}' > delete2insertproduct20231021.sqlsed -i "s/,);$/);/g" delete2insertproduct20231021.sqlvi  delete2insertproduct20231021.sql
#删除开头和补齐结束的SQL
8.通过处理后的insert into语句在SQL工具(我是HeidiSQL)逐步执行下,有异常可反复操作步骤6和7,以达到需要的效果。

注:一定不要在原数据库实例上操作。可以新建一个数据库实例和表进行操作。我是在测试环境的数据库进操作验证的,验证的数据同步到生产。再进行回滚数据的。

参考:

MySQL如何恢复不小心误删的数据记录(binlog)_mysql恢复误删的数据-CSDN博客

https://www.lmlphp.com/user/62049/article/item/2326681/

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

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

相关文章

pytorch 入门 (四)案例二:人脸表情识别-VGG16实现

实战教案二:人脸表情识别-VGG16实现 本文为🔗小白入门Pytorch内部限免文章 参考本文所写记录性文章,请在文章开头注明以下内容,复制粘贴即可 🍨 本文为🔗小白入门Pytorch中的学习记录博客🍦 参…

系统性认知网络安全

前言:本文旨在介绍网络安全相关基础知识体系和框架 目录 一.信息安全概述 信息安全研究内容及关系 信息安全的基本要求 保密性Confidentiality: 完整性Integrity: 可用性Availability: 二.信息安全的发展 20世纪60年代&…

Linux tmux使用总结

文章目录 1 tmux介绍2 tmux概念会话Sessions、窗口Windows、面板Panesstatus line中字段含义 3 Sessions会话管理新建会话断开当前会话进入之前的会话关闭会话查看所有的会话 4 tmux快捷指令系统指令窗口(Windows)指令面板(Panes)…

免费领取!TikTok Shop “全托管”黑五大促官方备战指南来啦!

黑五网一大促即将来袭,自“全托管”模式上线以来,TikTok for Business在沙特阿拉伯和英国市场开展了古尔邦节大促、夏季大促、返校季大促等活动,今年更是会借着黑五网一大促之际,首次覆盖美国市场,为全托管商家带来全球…

什么是接口测试?三分钟带你全面认识接口测试、带你学会接口测试~

目录 1、接口是什么? 2、接口的类型 3、接口测试初识 3.1、什么是接口测试 3.2、原理 3.3、特点 3.4、什么是自动化接口测试 4、接口测试流程 5、传统风格接口与RESTful风格接口 6、接口文档 6.1、什么是接口文档 6.2、接口文档作用 6.3、展现形式 6.4…

formData对象打印不出来

用el-upload上传图片 以流的形式传给后台 所以用formData对象带数据 let formData new FormData() formData.append(name,monkey7) console.log(formData) 明明已经把数据append进去了 console.log在控制台却打印不出 后来发现他得用formData.get("xxx"…

最全的图床集合(国内外,站长必备)

“heosu每月不定时更新嗷,防止错过消息推送,建议小伙伴添加到星标⭐喔” 为了减少服务器的压力不少站长还是选择图床存放图片的。所以就搜集一些比较好用的免费的图床(收费的在最后标出)以及我目前在用的图床。 为什么需要图床&am…

Linux系统CH347应用—SPI功能

Linux/安卓系统使用CH347转接SPI功能有三种应用方式: 1. 使用CH34X_MPHSI_Master总线驱动为系统扩展原生SPI Master,此方式无需进行单独的应用层编程; 2. 使用CH341PAR_LINUX字符设备驱动,此方式需要配合使用厂商提供的库文件&a…

【springcloud-config】配置中心客户端导入依赖spring-cloud-config-server后,maven一直爆红问题解决

问题描述 配置中心客户端导入了 spring-cloud-config-server 后&#xff0c;导入依赖爆红&#xff1b; 解决办法&#xff1a; 参考官网中文文档&#xff1a;spring-cloud -config 配置中心 中文文档 补充导入 spring-config-starter-config 配置即可 <!--springcloud-c…

跨境商城源码可以支持多种营销推广方式吗?

一、多种营销推广方式的重要性 跨境商城源码作为现代电商领域的重要工具&#xff0c;其支持多种营销推广方式对于吸引用户、增加销量以及提升品牌影响力都至关重要。通过采用多种营销推广方式&#xff0c;商家可以全方位地宣传和推广产品&#xff0c;吸引更多的潜在顾客&#x…

JS多选答题时,选项互斥时的情况

在做答题类的项目时&#xff0c;应该会比较常见多选题选相互斥的问题&#xff0c;例如&#xff1a; 你喜欢什么颜色&#xff1f;&#xff08;&#xff09;A、红色B、紫色C、蓝色D、灰色E、均无如该题&#xff0c;当选择选项E时&#xff0c;明显与其他选项互斥。这个时候经常会…

SAP 公司间销售

一、 概述 很多项目中&#xff0c;特别是集团型公司&#xff0c;生产总部在某地&#xff0c;但是在各个省会城市&#xff0c;乃至国外都有相应的贸易公司&#xff0c;特别是国外&#xff0c;此时贸易公司接到客户采购订单&#xff0c;但是贸易公司没有库存&#xff0c;甚至没有…

Zoho Mail荣登福布斯小型企业企业邮箱排行榜

在过去的数十载里&#xff0c;电子邮件已成为电子通信领域中不可或缺的一环&#xff0c;而在未来的岁月里&#xff0c;它有望继续在全球范围内普及应用。尽管如今市场上有许多免费的企业邮箱供用户和企业选用&#xff0c;但其中许多产品在特定场景下的专业化功能尚显不足&#…

selenium多窗口、多iframe切换、alert切换

多标签/多窗口之间的切换 场景&#xff1a; 在页面操作过程中有时候点击某个链接会弹出新的窗口&#xff0c;这时就需要切换到新打开的窗口上进行操作。这种情况下&#xff0c;需要识别多标签或窗口的情况。 操作方法&#xff1a; switch_to.window()方法&#xff1a;切换窗口…

如何高效的开展app的性能测试?

APP性能测试是什么 从网上查了一下&#xff0c;貌似也没什么特别的定义&#xff0c;我这边根据自己的经验给出一个自己的定义&#xff0c;如有巧合纯属雷同。 客户端性能测试就是&#xff0c;从业务和用户的角度出发&#xff0c;设计合理且有效的性能测试场景&#xff0c;制定…

js给一段话,遇到的第一个括号处加上换行符

list.forEach((item,index0)>{const productName item.name;const index productName.indexOf(&#xff08;);if (index -1) {return productName;}const before productName.slice(0, index);const after productName.slice(index);item.namebefore \n after;});

吃透Spring源码分析专题

想说的话 本人在互联网摸爬滚打至今(23年)6年了&#xff0c;平时有写博客的习惯&#xff0c;这个习惯是从大学的时候开始的&#xff0c;目前主要关注java领域相关的技术&#xff0c;python也有涉及&#xff0c;写Spring专题是因为Spring确实很重要&#xff0c;在目前这个开发模…

【C++】二叉树进阶 -- 详解

一、二叉搜索树概念 二叉搜索树 又称二叉排序树&#xff0c;它或者是一棵空树&#xff0c;或者是具有以下性质的二叉树&#xff1a; 若它的左子树不为空&#xff0c;则左子树上所有节点的值都小于根节点的值 若它的右子树不为空&#xff0c;则右子树上所有节点的值都大于根节点…

AI驱动的图纸数据提取

推荐&#xff1a;用 NSDT编辑器 快速搭建可编程3D场景 你是否曾经需要组合来自两个不同来源&#xff08;例如图像和文本&#xff09;的对象数据&#xff1f; 我们在工作的过程中经常面临这样的挑战。 在这里&#xff0c;我们展示了技术绘图领域的一个示例。 此类图纸用于许多领…

Python数据挖掘 | 升级版自动查核酸

&#x1f4d5;作者简介&#xff1a;热爱跑步的恒川&#xff0c;致力于C/C、Java、Python等多编程语言&#xff0c;热爱跑步&#xff0c;喜爱音乐的一位博主。 &#x1f4d7;本文收录于恒川的日常汇报系列&#xff0c;大家有兴趣的可以看一看 &#x1f4d8;相关专栏C语言初阶、C…