位置: 编程技术 - 正文

MySQL中truncate误操作后的数据恢复案例

编辑:rootadmin

推荐整理分享MySQL中truncate误操作后的数据恢复案例,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

实际线上的场景比较复杂,当时涉及了truncate, delete 两个操作,经确认丢数据差不多7万多行,等停下来时,差不多又有共计1万多行数据写入。 这里为了简单说明,只拿弄一个简单的业务场景举例。

测试环境: Percona-Server-5.6.日志格式: mixed 没起用gtid

表结构如下:

基于某个时间点有一个备份或是有全量的binlog是能恢复数据的一个唯一保证。 例如我们的备份就是一个表结构创建语句,binlog pos相关信息: mysql-bin. , 4,然后进行了如下:

?t1时间 程序写入:

?t2时间 某个人员失误

?t3时间 程序写入

MySQL中truncate误操作后的数据恢复案例

现在表里的数据情况:

可以见truncate table操作后,表的自增id又变更为从1开始,原来写入的数据应该是:

如果没生truncate table操作,实际的数据应该为:

而且线上的恢复那个表时和序序开发人员了解才知道,原来那个id和缓存及其它地方有依赖,因为id乱了,也会造成程序错乱。这个时间修复id在程序层错乱的事,留给开发人员了关建是给他们讲明白恢复的结果是什么样,我们的关建任务是把数据恢复出来。好,接下来的工作是开始从binlog中恢复数据。利用: show binary logs; 查看当的log文件分布, 然后利用show binlog events in ‘binary log文件'; 查看log文件的内容,目的是找到truncate发生的日志位置。另外因为基于备份(由log的启始位置)或是从量log, 如果基于备份有log的起始位置,我们需要处理的log文件是启始位置到发生truncate的日值(后面的数据处理不了,会发生主建冲突的错误造成truncate后的数据不能恢复),如果是全量日志,需要从创建完mysql后库后的日志去处理到当前的发生truncate的位置(后面数据会因为主建冲突写不进去)恢复准备工作,创建一个库用于恢复数据,这里创建了一个re_wubx, 及原结构的表: tb_wubx (相当于恢复了备份,过程省略)

我这里有一个备份文件就是那个创建表的sql语句,位置是mysql-bin. , 4在这个案例里我只用cover住mysql-bin.这个文件。

看到这个表刚开始就发生一次truncate, 那其实也可以说明我就恢复刚开始那个truncate到后来那个误操作的truncate table的语句之间的数据就是丢失的数据。这个恢复可以从mysql-bin. pos: 4到mysql-bin. pos: 即:

恢复结果如下:

恢复完成。

在MySQL中生成随机密码的方法 cat/dev/urandom|LC_ALL=Ctr-dc"[:alnum:]"|fold-w|head-Si1N9kUyuZddzsRXFgxAcaDRBRT4PxbuGk6LkX4dN5Xod1TOyrcBxAjlKRjwJR2TxunhQedXagL9RraDEZgfhYQxCurm5eZF参数说明:如果需要特别复杂的

MySQL中从库延迟状况排查的一则案例 今天给一个客户巡检的情况下发从库没有业务的情况mysqld的cpu的一个core占用%.查主库慢查询也没有关于写的SQL.可以说是典的单进程复制把一个cpu占满

在MySQL中使用mysqlbinlog flashback的简单教程 简介:mysqlbinlogflashback功能是淘宝彭立勋(

标签: MySQL中truncate误操作后的数据恢复案例

本文链接地址:https://www.jiuchutong.com/biancheng/347346.html 转载请保留说明!

上一篇:MySQL中修改库名的操作教程(mysql如何修改数据库名)

下一篇:在MySQL中生成随机密码的方法(mysql 随机io)

  • 进项税额转出就是要多交税吗
  • 应交税费负数调整到其他非流动资产
  • 个人捐赠支出税前扣除条件
  • 库存商品和固定资产
  • 通行费机打发票税率
  • 押金收不回来没钱怎么办
  • 个人所得税核定征收税率表
  • 出国考察需要什么手续
  • 期末库存农产品进项转出如何算
  • 农产品核定扣除范围
  • 股权投资公司如何找项目合作
  • 进项税额转出补交税金会计分录
  • 退款扣除的手续费怎么查
  • 老板给的钱计入什么科目
  • 发票认证后1年还能用吗
  • 发票勾选没有确认怎么办
  • 2018年2月1日以后出口发票如何开具
  • 建筑企业1%承包承租个人所得税的会计分录
  • 补贴收入需要缴纳增值税吗为什么
  • 营改增对小规模的影响
  • 合并起来
  • 通讯费发票抬头为个人能否报销
  • 工程预算调整的主要内容
  • 垫付的医药费怎么理赔
  • 建安企业外地项目预缴增值税
  • 支出凭证的日期
  • 对方不开票
  • 小企业会计准则适用于哪些企业
  • 某公司购入一台需要安装的生产设备
  • 只有土地使用权房子拆了怎么办
  • 会计科目对应的会计要素
  • php实现的一致性是什么
  • Yii2隐藏frontend/web和backend/web的方法
  • 企业合并收购,对员工的机会和挑战
  • 贷款房屋评估费怎么收
  • php string函数
  • 什么叫错账调整
  • 环形链表入口节点
  • 手相算命图解大全女
  • css图片适应div
  • php图片链接
  • php5升级到php7
  • mac vue搭建本地环境
  • 餐厅的餐具怎么摆
  • 解决前端跨域问题
  • html中的标签有哪些
  • 个税申报系统操作指南
  • js数组常用方法有哪几种
  • 差额征税怎么交税
  • 税务滞纳金计入什么会计科目
  • 补充医疗保险会查hiv吗
  • python中的生成器
  • 资产负债表中没有专项储备怎么填写
  • 报销发票啥意思
  • 发票已开不确认收入可以做吗?
  • 合作社分红计入什么科目
  • 劳务派遣公司开票内容写什么
  • 关联方交易金额达到多少算转移定价
  • 未分配利润转增股本
  • 发放股票股利如何影响计算基本每股收益
  • 十二月份没出现问题
  • “制造费用”账户如何设置明细账?
  • ubuntuiso
  • linux系统中安装软件
  • 彻底禁止win11自动更新
  • win7任务栏颜色怎么改成蓝色
  • windows8使用教程
  • 在mac中运行exe
  • 腾讯电脑管家免费安装下载
  • cocos编程
  • JavaScript中的NaN代表什么
  • 原生js import
  • 关于ie浏览器下面说法正确的是
  • JS Timing
  • Python 基于豆瓣电影的可视化
  • jquery.js插件
  • Python黑魔法手册
  • 增值税普通电子发票有什么用
  • 出口退税收入怎么做账
  • 深圳电子税务局app
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设