在工作中,我们误删数据或者数据库,我们一定需要跑路吗?我看未必,程序员一定要学会自救,神不知鬼不觉的将数据找回。

在 mysql 数据库中,我们知道 binlog 日志记录了我们对数据库的所有操作,所以 binlog 日志就是我们自救的利器。

接下来就来开启程序员自救之路。

想要自救成功,binlog 这把利器一定要好,在自己之前,我们一定要确定我们有 binlog 这把利器,以下就是确保有 binlog 利器的操作。

1、确认数据库是否开启 binlog 日志

show variables like 'log_%';

查看红色圈出来的地方,如果为 ON 则表示开启,否则未开启。没有开启的话,就需要做以下操作。

2、开启 binlog 日志

如果未开启 binlog 日志的话,就需要开启 binlog 日志,在 MySQL 的配置文件中设置,如果你的是windowns 电脑则找到 my.ini 文件,unix 系统找到 my.cnf文件。在文件中修改或者配置如下参数:

# Binary Logging.
#日志文件的名字及存储路径
log-bin=D:\Mysql-binlog\mysql-bin
#设置日志格式
binlog-format=mixed

其中 binlog-format 有三种选项:

  • STATMENT:每一条会修改数据的 SQL 语句会记录在 binlog 中。
  • ROW:不记录每一条 SQL语句的上下文信息,仅记录哪条记录被修改。
  • MIXED:以上两种模式的混合使用,一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog,MySQL会根据执行的 SQL 语句选择日志保存方式。

3、重启 MySQL 服务器

4、再次确认 binlog 日志开启成功。

好了,操作完上面几步之后,我们就可以学习如何自救了,我们使用三个场景来分别演示误删数据、误删表、误删库的情况下如何自救。

在进入具体的场景前,我们先来准备演示需要的数据库、表和数据。

1、创建数据库pingtouge

create database pingtouge;

2、创建 student 表

create table student(id INT NOT NULL AUTO_INCREMENT,name VARCHAR(100) NOT NULL,num VARCHAR(40) NOT NULL,PRIMARY KEY (id )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

3、插入数据

insert into student(name,num)values('张三','1234');
insert into student(name,num)values('李四','1235');

有了数据之后,可以正式进入场景了, are you ready?

场景一:误删了某条数据

一不小心将 student 表中 id=1 的数据删除了。该怎么办?

凭着记忆手动插入这条数据吗?好像也不是不可以哇,能记住的都是天才,利用 binlog 日志才是王道。

使用 show master status命令,查看最新的 binlog 日志文件。

获取到最新的 binlog 日志文件后,使用 show binlog events in 'mysql-bin.000043';命令查看 binlog 日志文件,如下图所示:

binlog 日志记录了我们对数据库的所有操作,包括语句提交前和提交后的偏移量,在数据恢复时会使用到这两个偏移量。

在正式进入数据恢复之前,我们先来认识 MySQL 提供的一个工具:mysqlbinlog 。mysqlbinlog 是用来操作 binlog 日志文件,我们数据恢复就需要使用到它。

使用 mysqlbinlog 来恢复二进制日志文件,命令格式为:

 mysqlbinlog binlog日志文件 --start-position 初始偏移量的位置 --stop-position 结束偏移量的位置 | mysql -u root -p 数据库名称;

我们在 binlog 日志文件中找到 student 表中 id=1 这条数据在删除之前的最后一次操作的起始偏移量和结束偏移量,在上图中,我已经标出,起始偏移量为:710,结束偏移量为:996。有了这两个参数之后,我们就可以使用 mysqlbinlog 命令来恢复数据了。

执行:

 mysqlbinlog d:\Mysql-binlog\mysql-bin.000043 --start-position 710 --stop-position 996 | mysql -u root -p pingtouge;

如果命令执行成功的话,再次执行 select * from student命令,查看数据是否恢复。


从上图中,可以看出,我们成功的恢复了 student 表中 id=1 的这条数据。

场景二:误删了数据表

又是一不小心把表 student 给删除了。

对于误删表,同样可以使用 binlog 日志来恢复,毕竟 binlog 日记记录的是我们对 MySQL 的所有操作,跟恢复单条数据一样,我们同样需要在 binlog 日志文件中查找到起始偏移量和结束偏移量,用来恢复数据。

与单条数据不一样的是,对于表的偏移量,起始偏移量是创建表之前的开始偏移量,结束偏移量是删除数据库之前的最后一个结束偏移量。 如下图示:



一张图截不全,我就分两张图了。同样我们使用 mysqlbinlog 来恢复 student 表,执行:

 mysqlbinlog d:\Mysql-binlog\mysql-bin.000043 --start-position 393 --stop-position 1997 | mysql -u root -p pingtouge

命令执行完成后,再次执行 select * from student;,你会发现我们的数据都回来了。

场景三:误删了数据库

你在工作中受气了,准备删库跑路啦,于是你就把pingtouge数据库给删除了,删完之后你就后悔了,怎么办?在线等。

不要慌,万能的 binlog 日志可以救你,跟前面两种场景一样,还是在 binlog 日志中查询到需要恢复数据库的起始偏移量和结束偏移量。这里我就不截图了。

通过查看 binlog 日志发现创建数据库pingtouge的开始偏移量为 219,删库之前的最后偏移量为 3861,有了这两个偏移量之后,执行:

mysqlbinlog d:\Mysql-binlog\mysql-bin.000043 --start-position 219 --stop-position 3861 | mysql -u root -p

需要注意的是最后不需要带上数据库,执行完之后,发现与数据库pingtouge相关的数据全部都回来了。

删库了,我们不一定需要跑路,一定要学习自救,少年。

以上就是今天分享的内容,希望对您的学习或者工作有所帮助,如果您觉得文章不错,欢迎点个赞和转发,谢谢。

删库了,我们一定要跑路吗?相关推荐

  1. 教师节快乐:删了库之后,不要着急跑路

    今天是教师节,祝天下的老师们:节日快乐,身体康健,授业解惑,桃李天下! 早上在朋友圈刷了一张图,引起了很多朋友的反馈,其实老师们的心思你懂的. 当年悟空学艺于菩提祖师门下,老师遣他下山,悟空觉得自己蒙 ...

  2. 删库跑路大神「后悔」了?我只不过犯了大家都会犯的编程错误!

      视学算法报道   编辑:好困 袁榭 [新智元导读]在开源程序界惹出「删库跑路」大新闻的开发者Marak Squires,最近发声:「人无完人,编程错误而已,GitHub你就不用再封我号了嘛!」 2 ...

  3. 成天说要删库跑路,这次真的有人干了

    说句玩笑,乍一看到这条新闻时,还以为是微软系统被员工删库了,吓了我一跳. "删库跑路",一直是程序员们的口头禅,但很少有人敢做这样的事情,毕竟容易牢底坐穿了. 之前发生过某科技公司 ...

  4. 试用期被劝退,京东到家某程序员删库跑路,被判刑10个月!

    最近,又有程序员因为"删库跑路"被判刑. 根据上海市杨浦区人民法院的消息,京东到家一名程序员未经公司许可,在离职当天私自删除了京东到家平台系统代码,构成破坏计算机信息系统罪,被判处 ...

  5. 暴力拒绝白嫖,著名开源项目作者删库跑路!神秘Bug影响超2万个项目,亚马逊云也躺枪...

    [文章来源][公众号:新智元] "从GitHub上删除自己的代码是违反他们的服务条款的?WTF? 这是一种绑架行为." 这两天,一些开发者感觉有点懵-- 一觉醒来发现,自己程序跑出 ...

  6. 漫画:如何给女朋友解释什么是删库跑路?

    作者 | 漫话编程 来源 | 漫话编程(ID:mhcoding) 在DBA圈子有这样一个段子: 最近几年,经常会出现各种删库跑路的事件发生,前几天还有报道说思科离职5个月的程序员,为了报复公司,删虚拟 ...

  7. 删库跑路升级版,著名大厂员工离职为报复公司,直接删虚拟机!

    作者 | 纯洁的微笑 来源 | 纯洁的微笑(ID:keeppuresmile) 全世界的程序员都一样,被逼急了都会做出毁灭性的行为... 来自印度的程序员 在大西洋的加利福尼亚州,有一个程序员叫做 S ...

  8. fox pro删除单条数据_删库之后不要着急跑路,教你神不知鬼不觉找回数据

    在工作中,我们误删数据或者数据库,我们一定需要跑路吗?我看未必,程序员一定要学会自救,神不知鬼不觉的将数据找回. 在 mysql 数据库中,我们知道 binlog 日志记录了我们对数据库的所有操作,所 ...

  9. 删库跑路大神的一生:曾在家造炸弹被捕,现卖房押宝NFT,原是开源创业之星...

    梦晨 萧箫 发自 凹非寺 量子位 报道 | 公众号 QbitAI "著名开源项目被作者本人删了库"这个瓜,现在是越吃越大了. 「faker.js」和「color.js」的作者Mar ...

  10. 著名开源项目,神秘Bug影响超20000个项目,原因竟是作者删库跑路?

    热门资讯早知道,吃瓜唠嗑不冷场, 记得加个星标,第一时间获得推送 图文编辑:xj 来源:公众号「新智元」 "从GitHub上删除自己的代码是违反他们的服务条款的?WTF? 这是一种绑架行为. ...

最新文章

  1. Android清空Fragment缓存,清空Fragment来退栈中某个Fragment
  2. javascript继承机制
  3. intelij不识别java文件
  4. 前端学习(1952)vue之电商管理系统电商系统之级联选择器
  5. mysql 转义字符6_MySQL的转义字符
  6. 批量安装Windows补丁
  7. OpenAI升级Codex,直接将书面语言转为计算机代码;区块链网站被黑客偷走6亿美元加密货币|极客头条...
  8. 面向对象的三大特性之多态,封装基础
  9. 在CentOS7上安装MySQL的心路历程
  10. c语言课程设计作业医院挂号系统,【c语言课程设计】医院门诊系统
  11. 探究VS2017运行库
  12. VS2019官方下载地址
  13. php微信上传头像,微信小程序怎么上传头像
  14. JAVA看云判断天气_如何看云识天气
  15. 《阿尔比恩的种子》pdf、mobi、epub
  16. 包装类的使用:自动装箱与自动拆箱
  17. javaweb学生签到考勤请假系统
  18. NR基础篇上——均值滤波、高斯滤波、双边滤波、NLM
  19. 大学“电路分析基础”试题合集第四章
  20. C# Winform 置顶属性Topmost 的误区

热门文章

  1. NOIP 2013 day1
  2. 游历校园 [COGS 614] [欧拉图]
  3. 利用微软类库 Visual Studio International Pack 汉字转拼音
  4. 用etree解析xml_用python3教你任意Html主内容提取
  5. n分频器 verilog_基于Verilog的分频器实现
  6. 蓝牙配对模式 java_BLE(低功耗蓝牙)配对和绑定
  7. flask高级编程 LocalStack 线程隔离
  8. django orm 操作符
  9. 使用C#获取IP地址方法
  10. knockout checkbox 全选