失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 面试官问:MySQL误删表数据 如何快速恢复丢失的数据?

面试官问:MySQL误删表数据 如何快速恢复丢失的数据?

时间:2022-02-08 01:56:09

相关推荐

面试官问:MySQL误删表数据 如何快速恢复丢失的数据?

相信后端研发的同学在开发过程经常会遇到产品临时修改线上数据的需求,如果手法很稳那么很庆幸可以很快完成任务,很不幸某一天突然手一抖把表里的数据修改错误或者误删了,这个时候你会发现各种问题反馈接踵而来。

如果身边有BDA或者有这方面经验的同事那么可以很快解决这个问题,如果没有那么希望这篇文章可以帮到你。

第一步:保证mysql已经开启binlog,查看命令:

查看binklog是否开启

showvariableslike'%log_bin%';

查看binlog存放日志文件目录(如下图,博主binlog目录为/data/mysql):

showvariableslike'%datadir%';

值为OFF,需开启,值为ON,已开启。

如果没有开启binlog,也没有预先生成回滚SQL,那可能真的无法快速回滚了。对存放重要业务数据的MySQL,强烈建议开启binlog。

第二步:进入binlog文件目录,找出日志文件

第三步:切换到mysqlbinlog目录(当线上数据出现错误的时候首先可以询问具体操作人记录时间点,这个时候可以借助mysql自带的binlog解析工具mysqlbinlog,具体位置在mysql安装目录**/mysql/bin/下)

第四步:通过mysqlbinlog工具命令查看数据库增删改查记录(必须切换到mysqlbinlog目录才有效)

例子1:查询-11-12 09:00:00到-11-13 20:00:00 数据库为 youxi 的操作日志,输入如下命令将数据写入到一个备用的txt文件中

mysqlbinlog--no-defaults--database=youxi--start-datetime="-11-1209:00:00"--stop-datetime="-11-1320:00:00"/data/mysql/mysql-bin.000015>template_coupon_tb_product_category.txt

例子2:查询-11-12 09:00:00到-11-13 20:00:00数据库为 youxi 的操作日志,并输出到屏幕上

mysqlbinlog--no-defaults--database=youxi--start-datetime="-11-1209:00:00"--stop-datetime="-11-1320:00:00"/data/mysql/mysql-bin.000015|more

例子3:查询-11-12 09:00:00到-11-13 20:00:00数据库为 youxi 的操作日志,并且过滤出 只包括 template_coupon_tb_product_category 表数据的操作记录,输入如下命令将数据写入到一个备用的txt文件中

mysqlbinlog--no-defaults--database=youxi--start-datetime="-11-1209:00:00"--stop-datetime="-11-1320:00:00"/data/mysql/mysql-bin.000015|greptemplate_coupon_tb_product_category>template_coupon_tb_product_category.txt

mysqlbinlog 命令的语法格式:mysqlbinlogmysql-bin.0000xx|mysql-u用户名-p密码数据库名--------------------------------------------------------常用参数选项解释:--start-position=875起始pos点--stop-position=954结束pos点--start-datetime="-9-2522:01:08"起始时间点--stop-datetime="-9-2522:09:46"结束时间点--database=zyyshop指定只恢复zyyshop数据库(一台主机上往往有多个数据库,只限本地log日志)--------------------------------------------------------不常用选项:-u--user=name连接到远程主机的用户名-p--password[=name]连接到远程主机的密码-h--host=name从远程主机上获取binlog日志--read-from-remote-server从某个MySQL服务器上读取binlog日志

第五步:利用第四步输出的sql语句或者txt文本进行语句过滤,重新插入数据或更新数据。

作者:一个人的孤独自白

/-mrl/p/9959365.html

公众号“Java精选”所发表内容注明来源的,版权归原出处所有(无法查证版权的或者未注明出处的均来自网络,系转载,转载的目的在于传递更多信息,版权属于原作者。如有侵权,请联系,笔者会第一时间删除处理!最近有很多人问,有没有读者交流群!加入方式很简单,公众号Java精选,回复“加群”,即可入群!Java精选面试题(微信小程序):3000+道面试题,包含Java基础、并发、JVM、线程、MQ系列、Redis、Spring系列、Elasticsearch、Docker、K8s、Flink、Spark、架构设计等,在线随时刷题!------ 特别推荐 ------特别推荐:专注分享最前沿的技术与资讯,为弯道超车做好准备及各种开源项目与高效率软件的公众号,「大咖笔记」,专注挖掘好东西,非常值得大家关注。点击下方公众号卡片关注。点击“阅读原文”,了解更多精彩内容!文章有帮助的话,点在看,转发吧!

如果觉得《面试官问:MySQL误删表数据 如何快速恢复丢失的数据?》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。