从删库到还原

举报
一只牛博 发表于 2024/12/01 22:06:39 2024/12/01
【摘要】 教你如何补救删库删表操作

欢迎来到我的博客,代码的世界里,每一行都是一个故事


你只管努力,剩下的交给时间

小破站

重要的事情说第一遍:遇到这种事情一定要冷静,别慌,先喝口水,再找到我这篇博客

相信大家第一眼看到标题也是很诧异,但是在日常工作中总是有些大佬会无意执行这样的操作,这不我就遇到好几次了

正常情况我们是没有资格执行这个删库的命令的,最多你可以执行的是delete table,update table set

大家也肯定注意到了,这两条语句都很危险,因为没有条件。噩梦可能就是从你点击的那一刻开始,比如我这样的操作。

因为没有条件,导致整个表的数据都被改变了,当时真想哭爹喊娘。接下来我们进行一些骚操作让你复原表

重要的事情说第二遍:遇到这种事情一定要冷静,别慌,先喝口水,再找到我这篇博客

魔法一

如果你在Navicat上操作的,并且你操作的表是之前打开的,而且数据只有不到1000条(Navicat的默认分页数),那么恭喜你,这个魔法适合你。

  1. 回到这个表中,你可以发现数据没变,此时千万别抱着好奇的态度,为什么没变呢,去点击刷新,一点击就完犊子了。

  2. 将所有数据复制为insert语句,以及update语句(双重保险),然后你可以刷新看一下,发现数据就变为你误操作的数据了,此时你将复制好的insert以及update,执行一下(如果你执行的是delete,就用insert,如果是update就用update)

可以看下数据压根没进行更新,美滋滋。

魔法二

如果魔法一没帮到你,我们来看下魔法二。正常情况下公司是每天会备份数据库的,所以第二种方法就是恢复备份数据了。

  1. 找到备份的sql文件
  2. 不管是备份的整个库,还是单个表,都不建议在刚刚操作的数据库或者表上操作
  3. 执行以下命令(如果你是多实例,建议换一个实例进行sql执行,如果是单实例,建议换一个库进行操作)
mysql -u'root' -p'123456' -S /home/mysql/3306/tmp/mysql_3306.sock test -e "source /home/backup/2024-05-24-01-00-02/test.sql"
  1. 备份原数据,再执行数据传输

魔法三

延迟主从,这个我认为在实际工作中非常有必要的,如果一些误操作,靠这个是完全可以恢复的,至于延迟的时间就需要仔细斟酌了,几分钟到几小时都可行。当然这个也没必要说太多,比如3306上的xiaobo库中的user表被删了,但是我有3307这个从库,延迟时间是10分钟,那么我直接就可以从3307中的xiaobo.user拷贝到3306的xiaobo.user中。

魔法四

这个魔法的前提是mysql开启了binlog,且为row。

查看是否开启binlog,且format为row

要查看 MySQL 是否已启用二进制日志(binlog)且格式为 ROW,可以使用 MySQL 命令行客户端连接到 MySQL 数据库,并执行以下命令:

SHOW VARIABLES LIKE 'log_bin';

这会显示 MySQL 是否已启用二进制日志,如果结果为 ON,则表示已启用二进制日志;如果为 OFF,则表示未启用。如果启用了二进制日志,可以继续检查日志格式:

SHOW VARIABLES LIKE 'binlog_format';

如果结果为 ROW,则表示二进制日志格式为 ROW。如果结果为 STATEMENTMIXED,则表示二进制日志格式为 STATEMENTMIXED

执行以下命令

mysqlbinlog --start-datetime="2024-05-24 09:52:00" --base64-output=decode-rows -vv mysql_binlog.000004

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。