位置: 编程技术 - 正文

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)

  • 撤销增值税申报流程
  • 流转税解释
  • 投标报名费开什么类别发票
  • 价税分离合同印花税的计税依据怎么算
  • 今年成立的公司,残保金是否要申报
  • 小规模纳税人残保金
  • 税控盘反写显没有数据怎么处理
  • 电子税务局中在哪看本月开票统计表
  • 转让专利属于什么分配
  • 缴纳文化事业建设费的范围
  • 冲账其他应付款
  • 进项税额留底月底销项税金如何结转?
  • 旧机动车交易需要哪些法定证件
  • 仓库的数量为负数怎么办
  • 企业名称变更后原名称还能使用吗
  • 装卸收入的增值税税率是多少
  • 个人非货币性资产出资 个人所得税
  • 个人交的税费报销如何做账?
  • 查验发票真伪新旧有哪些网站?
  • 已认证的发票对账怎么办
  • 填报企业所得税资产总额怎么填
  • 旅游合同签订
  • 物业公司代收水费亏损谁承担
  • 固定资产管理的论文
  • 投资公司抛售原始股如何交税?
  • 已计提月份的公式
  • 发票产生的材料是什么
  • 数字权利服务如何打开
  • 在win10中怎么从edge旧ie浏览器
  • 企业所得税预缴申报
  • php随机生成1到3的数字
  • PHP:ftp_nb_put()的用法_FTP函数
  • php中url
  • 公司备用金申请单
  • vue3 超好用的富文本编辑器
  • postman如何设置token
  • 火狐十大必用插件
  • laravel批量insert
  • 研发费用如何加计扣除何时申报
  • phpstudy删除
  • js写数组去重
  • 可予税前扣除的合理部分
  • 小型微利企业增值税优惠政策2023最新
  • 公司当月没有人发工资
  • php 引入
  • 更正申报会扣分吗
  • 将自产产品用于赠送
  • 购买房屋缴纳的契税可以退税政策
  • 金税四期功能
  • 先付款后开票怎样写证明
  • 简易计税怎么算增值税
  • 生产车间计提费用会计分录
  • 研发设备的折旧计入研发费用吗
  • 加工费如何开增票
  • 个人如何缴纳公积金和社保费用
  • 施工企业会计成本费用论文3000字
  • 城市综合配套
  • 金融资产减值损失
  • 个体工商户记账报税教程
  • 股权变更产生的税费
  • 如何开展服务工作
  • 自动备份mssql server数据库并压缩的批处理脚本
  • navicat查询结果下面输出栏如何关闭
  • mysql数据库基本知识点总结
  • 返回sql执行时间的方法
  • mysql id in
  • windows2008r2修改密码
  • linux搭建gitlab
  • ubuntu系统安装谷歌浏览器
  • U盘安装ubuntu的分区详细教程
  • win7系统怎么给文件夹设置密码
  • android 自定义view onlayout
  • opengl 2
  • 深入浅出javascript
  • nodejs登录成功跳转
  • android环境搭建实验报告
  • jquery cookie用法
  • jquery解析html文本
  • 厂房出租开增值税专用发票
  • 国税局黑龙江省
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设