mysqlbinlog delete恢复成insert

不小心把数据删掉了
首先要拿到binlog文件
执行以下命令行

/usr/local/mysql/bin/mysqlbinlog --base64-output=decode-rows --start-datetime=“2023-05-19 09:01:32” --stop-datetime=“2023-05-19 09:01:35” -v /Users/zylong/Downloads/mysql-bin.003178 --result-file=/Users/zylong/desktop/update.txt

/usr/local/mysql/bin/mysqlbinlog是你的mysqlbinlog所在的目录 如果你设置了环境变量可以不加全路径

–base64-output=decode-rows base64输出行

–start-datetime --stop-datetime 起止时间 具体去看binlog里想恢复的时间 如下图的230519 9:01:33 上述两个时间遵循左开右避原则

也可以使用at 具体到行 可以自行百度看看
在这里插入图片描述

-v /Users/zylong/Downloads/mysql-bin.003178 -v只想你的目标文件路径

–result-file= 输出到指定文件

输出完成后打开 上述txt文件 显示大概如下
在这里插入图片描述
执行以下命令
cat /Users/zylong/desktop/update1.txt | sed -n ‘/### /p;/# at/p’ | sed ‘s/### //g;s/DELETE FROM/INSERT INTO/g;s/WHERE/(ID, departname, description, parentdepartid, org_code, org_type, mobile, fax, address, depart_order, home_dep, is_contrast, total_contrast_number, total_observer_number, total_matched_number, contrast_mirror, current_contrast_number, illness, region_id, is_self_control, main_logo, is_bindable_wx, sms_template, sms_request_template, is_case_center) VALUES(/g;s/@1=//g;s/[0-9]=//g;s/@[0-9]/,/g;s/@/,/g;s/# at/);\n# at/g’ | sed -e ‘/# at/d’ > /Users/zylong/desktop/t6.txt
以上命令是sed 替换文本操作 不会的可以自己去看看 其实就是替换文本没啥难的 随便看看就明白了

以上分五部分依次是源文件 显示行 替换操作 删除操作 目标文件

/Users/zylong/desktop/update1.txt 源文件

其中红色以及黄色标注中的;表示匹配多个 如果你还有额外的需求可以再添加一个匹配或规则

sed -n ‘/### /p;/# at/p’

-n 表示源文件中显示的行 我们只需要sql相关的文件 所以只需要/### 开头的文件 但是我们替换的时候需要在每个sql命令后加上); 所以用到了/# at开头的行

1,s/### //g;

2,s/DELETE FROM/INSERT INTO/g;

3,s/WHERE/(ID, departname, description, parentdepartid, org_code, org_type, mobile, fax, address, depart_order, home_dep, is_contrast, total_contrast_number, total_observer_number, total_matched_number, contrast_mirror, current_contrast_number, illness, region_id, is_self_control, main_logo, is_bindable_wx, sms_template, sms_request_template, is_case_center) VALUES(/g;

4,s/@1=//g;

5,s/[0-9]=//g;

6,s/@[0-9]/,/g;

7,s/@/,/g

8,s/# at/);\n# at/g;

2,3 操作其实就是连成一个 insert into xxx (字段1,字段2…) values(

4 把第一个参数前的数据完全替换

5替换以数字开始=结尾的数据 替换成空字符

6,7 将@以及数字替换成,

8,将/# at 替换成分);# at \n表示换行 /g表示匹配多个 下同 其中/# at后面的/表示分开符号 如果要使用/请先转译

sed -e ‘/# at/d’ 删除包含“# at”的行

上述操作输出后大概就是这样

    insert into xxx (字段1,字段2...) values('1','2',...);

    insert into xxx (字段1,字段2...) values('1','2',...);

">"符号 表示输出到目标文件

/Users/zylong/desktop/t6.txt 目标文件

复制上述输出文件的内容 运行之后数据就恢复了

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

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

相关文章

蓝桥:前端开发笔面必刷题——Day1 数组(一)

文章目录 📋前言🎯数组中重复的数字📚题目内容✅解答 🎯两数之和📚题目内容✅解答 🎯替换空格📚题目内容✅解答 🎯二维数组中的查找📚题目内容✅解答 📝最后 …

C#串口通信从入门到精通(14)——多个串口接收数据

文章目录 前言1、多串口数据的接收2、源码前言 我们在开发串口通信程序时,有时候会需要连接不止一个串口,这时候该怎么写程序呢?本文就来介绍多个串口数据的接收 1、多串口数据的接收 我们在之前的专栏中介绍了串口数据的发送,当时有提到过,我们是通过创建一个SerialPo…

unity,如何让人物随着鼠标滑动而转向?

介绍 unity,如何让人物随着鼠标滑动而转向? 方法 using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.EventSystems;public class PlayerMovement : MonoBehaviour {public float speed 6f; …

RK3588平台开发系列讲解(进程篇)Linux文件系统数据结构

平台内核版本安卓版本RK3588Linux 5.10Android 12文章目录 一、Linux 文件系统数据结构有哪些二、超级块结构 spuer_block三、目录 dentry四、文件索引结点 inode五、打开的文件 file沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 本篇将介绍 Linux 文件系统数据结构…

IIC总线通讯协议学习

​ IIC(最简单的总线通讯,简单意味着通用和普适性) iic通讯一般采用一主多从的方式.同一时间要么在发送信息,要么在读取信息(半双工通讯) ​​​​​​​​​​​​​​ ​​​​ ​​​ 标准的写数据帧(主机向从机写数据) 解释以上的写数据帧 S:起始信号(在SCL…

什么是投入产出比(ROI)以及如何提升投入产出比?

投入产出比(ROI)是一种衡量企业或项目投资效益的指标,它可以帮助企业评估投资回报情况,并制定更加明智的投资决策。本文将为大家介绍什么是投入产出比(ROI)以及如何提升投入产出比。 一、什么是投入产出比&…

6年心得,从功能测试到测试开发,送给在测试路上一路走到黑的你

蓦然回首,软件测试风风雨雨的这就几年,起初每天的工作只是鼠标点点点,我还真不知道怎么办,闲的时候真的怀疑自己的存在价值,每天拿着7000的工资,飘荡在繁华的深圳,吃不饱也饿不死,未…

【UDS】诊断故障代码老化机制

文章目录 简介相关术语1. 老化计数器 Ageing counter2. 诊断故障代码已老去 DTC aged3. 已老去计数器 Aged counter4. 操作循环 Operation cycle5. 诊断故障代码老化机制 DTC aging mechanism 总结 ->返回总目录<- 简介 诊断故障代码&#xff08;DTC&#xff09;一旦生…

软件设计师考试笔记,已通过

目录 系统可靠度 外部实体 内聚类型 编译过程 逆波兰式 前驱图 scrum框架模型 编译和解释 有限自动机 聚簇索引和非聚簇索引 二叉树的前序,中序,后序遍历 动态规划贪心算法 算法 01背包问题 系统可靠度 1. 串联部件可靠度 串联部件想要这条路走通&#xff0c;只有…

062:cesium设置泛光折线材质(material-6)

第062个 点击查看专栏目录 本示例的目的是介绍如何在vue+cesium中设置泛光折线材质,请参考源代码,了解PolylineGlowMaterialProperty的应用。 直接复制下面的 vue+cesium源代码,操作2分钟即可运行实现效果. 文章目录 示例效果配置方式示例源代码(共89行)相关API参考:专…

开发框架Furion之WebApi+SqlSugar (一)

目录 1.开发环境 2.项目创建 2.1创建WebApi主项目 2.2 创建Start类库 2.3创建Model实体类库 2.4创建Application仓储业务类库 2.5创建Unility通用方法类库 3.基础功能配置 3.1 Model实体对象与数据表映射 3.2 基类仓储及动态Api接口配置 3.3 数据库IOC注册 3.4 Star…

JDK源码阅读环境搭建

本次针对jdk8u版本的搭建 1.新建项目 新建java项目JavaSourceLearn &#xff0c;这里我创建的是maven 2.获取JDK源码 打开Project Structure 找到本地JDK安装位置将src.zip解压到项目java包中 整理下项目结构&#xff0c;删除用不到的目录 提示: 添加源码到项目之后首次运行…

从零玩转设计模式之原型模式-yuanxingmoshi

title: 从零玩转设计模式之原型模式 date: 2022-12-11 20:05:35.488 updated: 2022-12-23 15:35:44.159 url: https://www.yby6.com/archives/yuanxingmoshi categories: - 设计模式 tags: - 设计模式 - 原型模式 什么是原型模式设计模式? 原型模式是一种软件设计模式&#…

公司招了一个00后,以为是个小年轻,没想到人家是个卷王...

公司前段缺人&#xff0c;也面了不少测试&#xff0c;结果竟然没有一个合适的。一开始瞄准的就是中级的水准&#xff0c;也没指望来大牛&#xff0c;提供的薪资也不低&#xff0c;面试的人很多&#xff0c;但平均水平很让人失望。 令我印象最深的是一个00后测试员&#xff0c;…

【Linux高级 I/O(2)】如何使用阻塞 I/O 与非阻塞 I/O?——select()函数

上次我们虽然使用非阻塞式 I/O 解决了阻塞式 I/O 情况下并发读取文件所出现的问题&#xff0c;但依然不够完美&#xff0c;使得程序的 CPU 占用率特别高。解决这个问题&#xff0c;就要用到本文将要介绍的 I/O 多路复用方法。 何为 I/O 多路复用 I/O 多路复用&#xff08;IO m…

AI 将完全取代前端开发吗?

注&#xff1a;今晨&#xff0c;我浏览 Medium&#xff0c;看到了篇颇为标题党的文章&#xff0c;于是我就将它抛给了 ChatGPT。本篇文章全部由 ChatGPT 所写。同时&#xff0c;我也请 ChatGPT 分享了它对此的观点。 最近&#xff0c;我的同事向我讲述了他与他老板的一次谈话。…

Python机器学习:Scikit-learn和TensorFlow的应用和模型设计

一、引言 Python在机器学习领域中已经成为非常受欢迎的编程语言。Scikit-learn和TensorFlow是Python中应用最广泛的两个机器学习库&#xff0c;它们提供了丰富的机器学习算法和工具&#xff0c;帮助开发人员轻松地构建和训练机器学习模型。本文将详细介绍Scikit-learn和Tensor…

功率放大器的选型原则和方法是什么

功率放大器是一种能够将低电平信号放大到足够高的电平以驱动负载的电子器件。在各种电子设备中&#xff0c;功率放大器被广泛应用&#xff0c;如音响系统、电视广播、汽车音响、射频通信等。因此&#xff0c;正确选型功率放大器非常重要&#xff0c;可以提高设备的性能和可靠性…

如何在linux中配置JDK环境变量

在linux系统部署皕杰报表&#xff0c;因皕杰报表是一款纯java报表工具&#xff0c;运行时需要jre环境&#xff0c;所以要在服务器上配置三个jdk环境变量path、classpath、JAVA_HOME。 那么为什么要配置jdk环境变量呢&#xff1f;因为java软件运行时要用到一些java命令&#xff…

Python挑选出无Labelme标注文件的图片文件

Python挑选出无Labelme标注文件的图片文件 前言前提条件相关介绍实验环境Python挑选出无Labelme标注文件的图片文件代码实现输出结果 前言 本文是个人使用Python处理文件的电子笔记&#xff0c;由于水平有限&#xff0c;难免出现错漏&#xff0c;敬请批评改正。 (https://blog.…