MySQL 恢复误删数据

news2024/10/7 0:27:25

文章目录

          • 1、查看是否启用 binlog 日志
          • 2、查看所有 binlog 日志
          • 3、查看正在使用的日志
          • 4、查找日志所在文件夹
          • 5、log 日志转 sql
          • 6、delete 转 insert 恢复误删

MySQL 恢复误删数据,针对 window 和 Linux 均适用,只需要找到对应的 binlog 目录文件,默认就是 MySQL 安装目录下的 data 文件夹

一般误删数据,先停止所有操作,备份数据库

# 备份所有数据库
mysqldump -uroot -p123456 --all-databases > /backup/mysqldump/all.db
# 恢复数据
mysql -uroot -p db_name < /backup/mysqldump/db_name.db
1、查看是否启用 binlog 日志
SHOW VARIABLES LIKE '%log_bin%'

在这里插入图片描述

2、查看所有 binlog 日志
SHOW BINARY LOGS;

在这里插入图片描述

3、查看正在使用的日志
SHOW MASTER STATUS;

在这里插入图片描述

4、查找日志所在文件夹
SHOW VARIABLES LIKE '%datadir%';

在这里插入图片描述

5、log 日志转 sql

使用上面使用的 binlog.000056 文件,先把 该文件复制到其他地方

mysqlbinlog E:\test\result\binlog.000056 > E:\test\result\db.sql

有可能报错
在这里插入图片描述
添加 --no-defaults 参数可以解决,但中文会乱码(使用下面 vbs 或自定义语言实现可解决 乱码问题),一般要加上时间字段转换 sql

mysqlbinlog --no-defaults --base64-output=decode-rows -v --database=oauth --start-datetime="2023-06-01 01:44:00" --stop-datetime="2023-06-01 01:48:00" F:\mysql-8.0.29-winx64\data\binlog.000058 > E:\test\result\db.sql

转换成功如下,可以看到删除 sql 的语句
在这里插入图片描述
接下来只需要将上面的 delete 语句转换为 inert 即可恢复误删数据,如果需要转换的多可以通过代码自定义实现,主要就是将
delete 转 insert

6、delete 转 insert 恢复误删

通过 vbs 脚本转换 sql 语句,当然也可以使用其他的语言,window 执行 vbs 不需要额外的环境,你只需要修改下面 vbs 文件中输入输出文件名以及编码类型即可

'==========================
'用VBS实现 MYSQL binglog DELETE 转 INSERT
'==========================
function replaceregex(patern,str,tagstr)
dim regex,matches
set regex=new regExp
regex.pattern=patern
regex.IgnoreCase=true
regex.global=true
matches=regex.replace(str,tagstr)
replaceregex=matches
end function

'Mysql binlog DELETE转INSERT==========
'VBS打开文本文件
Set oldStream = CreateObject("ADODB.Stream")
oldStream.CharSet = "utf-8"
oldStream.Open
'binLog 生成的 DELETE 原日志文件'
oldStream.LoadFromFile("E:\test\result\db.sql") 
oldText = oldStream.ReadText()
newText=replace(oldText,"### DELETE FROM", ";INSERT INTO")
newText=replace(newText,"### WHERE", "SELECT")
newText=replace(newText,"###", "")
newText=replace(newText,"@1=", "")
newText=replaceregex("@[1-9]=",newText, ",")
newText=replaceregex("@[1-9][0-9]=",newText, ",")
oldStream.Close
'VBS保存文件
Set newStream = CreateObject("ADODB.Stream")
newStream.Type = 2 'Specify stream type - we want To save text/string data.
newStream.Charset = "utf-8" 'Specify charset For the source text data.
newStream.Open 'Open the stream And write binary data To the object
newStream.WriteText newText
newStream.SaveToFile "mysqllogOK.sql", 2 'DELETE转成INSERT以后的新的SQL文件名
newStream.Close

转换结果如下,自行选择新增恢复数据

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【5G PHY】5G SLIV(Start and Length Indicator Value)介绍

博主未授权任何人或组织机构转载博主任何原创文章&#xff0c;感谢各位对原创的支持&#xff01; 博主链接 本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客…

玩转服务器之应用篇:从零开始构建小型高可用环境

高可用环境介绍 搭建高可用环境&#xff0c;可以消除单点故障的影响&#xff0c;使系统在出现故障时自动地切换到其它节点&#xff0c;保障系统的平稳运行&#xff0c;提高系统的可靠性和可用性&#xff0c;同时保证数据的安全性&#xff0c;高可用环境已经是现代企业应用的标…

【git】如何在本地保存git的密码

前言 这个其实在官网上也有&#xff0c;但是平时用的不多&#xff0c;基本弄过一次&#xff0c;长久受益。今天提交代码的时候&#xff0c;莫名其妙的叫我输入git密码&#xff0c;然而我早已忘记&#xff0c;于是乎就在网上找了很多命令在Git Bash Here上疯狂操作&#xff0c;…

记一次 String(-0) 引起的 bug

-0 在js中是存在的&#xff0c;可以通过 var a -0 得到&#xff0c;也可以通过 parseInt(-0.1) 得到 但是存在 -0 0, String(-0) String(0) 的情况 起初&#xff0c;业务中存在一个 给数字转换成 千分位数字字符串的方法 // numInt 为传入的值, 如 1035 let integer pars…

xilinx zynq ps端移植wxworks6.9系统

一&#xff0c;创建bootrom 打开打开Workbench&#xff0c;目录在C:\WindRiver\workbench-3.3\wrwb\platform\x86-win32\eclipse\eclipse-x86-win32 在菜单栏&#xff0c;点击 File->New->Project。The New Project Wizard opens。 在 VxWorks 6.x中&#xff0c;选择 Vx…

WDM波分复用器件的结构组成介绍

目前已知WDM波分复用技术有很多种&#xff0c;如&#xff1a;FBT (熔融拉锥&#xff0c;Fused Biconical Taper)、FBG(光纤布拉格光栅&#xff0c;Fiber Bragg Grating)、TFF (薄膜滤波&#xff0c; Thin Film Filter)、AWG (阵列波导光栅&#xff0c; Arrayed Waveguide Grati…

【GTest】C++在Linux上如何安装构建GoogleTest

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化 &#x1f449;专__注&#x1f448;&#xff1a;专注主流机器人、人工智能等相关领域的开发、…

chatgpt赋能python:Python内置字符串处理方法

Python内置字符串处理方法 Python是一种高级编程语言&#xff0c;拥有丰富的库和模块&#xff0c;方便开发者进行各种编程操作。同时&#xff0c;Python也提供了许多内置的字符串处理方法&#xff0c;使得字符串操作变得更加方便快捷。 字符串的定义 在Python中&#xff0c;…

AI实战营:人体姿态估计与MMPose

目录 人体姿态估计的介绍与应用 2D姿态估计 多人姿态估计&#xff1a;自顶向下方法 多人姿态估计&#xff1a;自底向上方法 多人姿态估计&#xff1a;单阶段方法 基于Transformer的方法 基于回归的自顶向下方法 DensePose(2014) 通过级联提升精度 回归方法的优势与劣…

考前必看|PMP考试通关宝典

项目进度管理 &#xff08;1&#xff09;项目进度计划 如何及何时交付项目范围中的产品、服务和成果&#xff0c;为绩效报告提供进度依据。 选择进度计划的方法&#xff0c;如关键路径法或敏捷方法。 &#xff08;2&#xff09;定义活动 活动由工作包分解而来&#xff0c;作…

【蓝桥杯选拔赛真题59】Scratch影院选座 少儿编程scratch图形化编程 蓝桥杯选拔赛真题解析

目录 scratch影院选座 一、题目要求 编程实现 二、案例分析 1、角色分析

SpringCloudAlibaba:服务容错之Sentinel学习

目录 一、高并发带来的问题 服务雪崩效应 二、常见容错方案 &#xff08;一&#xff09;隔离 &#xff08;二&#xff09;超时 &#xff08;三&#xff09;限流 &#xff08;四&#xff09;熔断 &#xff08;五&#xff09;降级 三、常见的容错组件 四、Sentinel概述 …

子集-回溯算法

1题目 给你一个整数数组 nums &#xff0c;数组中的元素 互不相同 。返回该数组所有可能的子集&#xff08;幂集&#xff09;。 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,3] 输出&#xff1a;[[],[1],[2],[1…

SpringBoot项目整合Redis作为缓存中间件的详细步骤

SpringBoot项目整合Redis作为缓存中间件的详细步骤 1.链接2.整合步骤3.测试Demo4.遇到的问题5.待考虑问题 有更好的建议&#xff0c;欢迎评论区留言~ 有不详细或者不准确的地方&#xff0c;欢迎评论区指正~ 有技术群嘛 hahh 可以拉我么 ~ 1.链接 哔哩教程视频 Redis官方 2.整…

线程池的工作原则揭秘:如何合理管理线程数量?

大家好&#xff0c;我是小米&#xff0c;一个热爱技术分享的小伙伴。在多线程编程中&#xff0c;线程池是一种非常实用的工具&#xff0c;可以帮助我们更好地管理线程&#xff0c;提高程序的性能和稳定性。今天&#xff0c;我将详细介绍线程池的概念、使用方法以及常用参数&…

MFC 状态栏梳理

MFC状态栏梳理 MFC状态栏&#xff0c;觉得挺简单的&#xff0c;但是用的时候总是不得劲&#xff0c;梳理了一下代码。理解通透些。 先说状态栏窗口怎么来的 在MainFrame里面会有一个成员变量&#xff0c;状态栏 m_wndStatusBar protected: // 控件条嵌入成员CMFCMenuBar …

VMware ESXi 8.0U1a 发布 - 领先的裸机 Hypervisor

VMware ESXi 8.0U1a 发布 - 领先的裸机 Hypervisor 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-esxi-8-u1/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;sysin.org 2023-06-01, VMware vSphere 8.0U1a 发布。 详见&am…

I.MX6ULL_Linux_驱动篇(36) GPIO输入驱动

在前面我们都是使用的 GPIO 输出功能&#xff0c;还没有用过 GPIO 输入功能&#xff0c;本章我们就来学习一下在 Linux 下编写 GPIO 输入驱动程序。我们使用一个 GPIO 加输入驱动程序&#xff0c;同时利用原子操作来对按键值进行保护。 按键驱动和 LED 驱动原理上来讲基本都是…

浅谈TTF字体和Fnt字体的本质和优缺点

前言 本篇在讲什么 浅浅对TTF字体和Fnt字体的本质了解一下 本篇的特色 具有全流程的图文教学 重实践&#xff0c;轻理论&#xff0c;快速上手 提供全流程的源码内容 ★提高阅读体验★ &#x1f449; ♠ 一级标题 &#x1f448; &#x1f449; ♥ 二级标题 &#x1f448…

【Java 接口】接口(Interface)的定义,implements关键字,接口实现方法案例

博主&#xff1a;_LJaXi Or 東方幻想郷 专栏&#xff1a; Java | 从入门到入坟 专属&#xff1a;六月一日 | 儿童节 Java 接口 接口简介 &#x1f383;接口的定义 &#x1f9e7;接口实现类名定义 &#x1f381;接口实现类小案例 &#x1f388;后话 &#x1f3b0; 接口简介 &…