首页 > 数据库 >MySQL误删恢复方法1

MySQL误删恢复方法1

时间:2022-11-14 10:14:21浏览次数:50  
标签:闪回 -- 恢复 MyFlash 误删 MySQL 操作 flashback

MySQL不同于oracle,没有闪回查询这类概念,但网上流传几个闪回的开源工具如 binglog2sql、MyFlash,可以使用binglog日志进行误操作数据的恢复。
笔者以前测试过 binglog2sql,发现安装配置比较复杂不太友好。
本次测试了下 MyFlash 这个开源工具,发现相对简单易用,特此做一个使用记录。
MyFlash是由美团点评公司技术工程部开发维护的一个回滚DML操作的工具。该工具通过解析v4版本的binlog,完成回滚操作。相对已有的回滚工具,其增加了更多的过滤选项,让回滚更加容易。

目录

■ MyFlash 安装

下载:
wget https://github.com/Meituan-Dianping/MyFlash/archive/refs/heads/master.zip
解压缩、动态编译链接:
unzip master.zip && cd MyFlash-master
gcc -w `pkg-config --cflags --libs glib-2.0` source/binlogParseGlib.c -o binary/flashback

如编译时遇到复杂难解问题,可以换机器编译操作!

■ 执行闪回操作

默认会将闪回结果存放到 binlog_output_base.flashback

./flashback --databaseNames=dbname --tableNames=tblname --sqlTypes='DELETE' --start-datetime="2022-10-27 16:54:00" --stop-datetime="2022-10-27 18:27:00" --binlogFileNames=binlog.000288

■ 确认是否想要的恢复操作

mysqlbinlog --no-defaults --base64-output=decode-rows -vv binlog_output_base.flashback | grep "INSERT" | wc -l

可见有大约 9864 个 insert 操作,对应误删时段的 delete 操作

■ 应用闪回日志恢复误删

mysqlbinlog binlog_output_base.flashback | mysql -u'root' -p'passwd'

标签:闪回,--,恢复,MyFlash,误删,MySQL,操作,flashback
From: https://www.cnblogs.com/likingzi/p/16888132.html

相关文章

  • MySQL误删恢复方法2
    实际工作中总会发生数据误删除的场景,在没有备份情况下,如何快速恢复误删数据就显得非常重要。本文基于MySQL的binlog日志机制,当日志格式设置为“binlog_format=ROW”时,记录......
  • mysql中的found_rows() 与 row_count()函数
    1.found_rows()found_rows()用于查询同一连接下,上一条执行select查询返回的行数,包括show语句返回的行数。中间可以插入执行dml语句,返回依然是上一条select语句返回的行......
  • ubuntu安装 MySql5.7.bundle.tar
    1.查询是否有残留软件rpm-qa|grepmysqlrpm-qa|grepmariadb2.上传解压并安装root@kht:/kht#tar-xvfmysql-5.7.40-1.el7.x86_64.rpm-bundle.tarmysql-communi......
  • MySQL 通过 binlog 日志恢复数据
    binlog日志,即binarylog,是二进制日志文件,有两个作用,一个是增量备份,另一个是主从复制,即主节点维护一个binlog日志文件,从节点从binlog中同步数据,也可以通过binlog日......
  • mysql benchmark
    数据库创建用户密码数据库,字段值均为benchmark。安装sysbench,执行命令。测试结果:#u-ubuntu-vmexportMYSQL_HOST=192.168.1.10#准备数据sysbench--db-driver=my......
  • MySQL高级6【MVCC-其他日志-主从复制-备份与恢复】尚硅谷
    【第16章多版本并发控制】1.什么是MVCCMVCC(MultiversionConcurrencyControl),多版本并发控制。顾名思义,MVCC是通过数据行的多个版本管理来实现数据库的并发控制。这......
  • Ubuntu 20.04 安装部署 MySQL 8.0
    1.规划官网:MySQL社区官网,下载包需要创建oracle账户,本地使用的是Linux通用的二进制包mysql-8.0.31-linux-glibc2.12-x86_64.tarmd5:89e902edeb75216c366e878f3c9e85be......
  • MySQL优化
    一、       MySQL数据库-SQL优化MySQLDBMS-MySQLDatabaseManagementSystem。数据库管理系统。1       结构图   2       MySQL......
  • 使用MySQL时出现The server time zone value '�й���׼ʱ��' is unrecogni的解决方法
    问题:Causedby:com.mysql.cj.exceptions.InvalidConnectionAttributeException:Theservertimezonevalue'�й���׼ʱ��'isunrecognizedorrepresentsmorethanoneti......
  • MySQL数据库连接参数
    数据库连接参数driver-class-name:com.mysql.cj.jdbc.Driver//&serverTimezone=GMT%2B8连接使用的时区,一般是MySQL8+版本使用的url:jdbc:mysql://localhost:3306/......