mysql binlog统一恢复误删数据库、表、数据(没有任何备份)

先将mysql文件夹中的my.ini进行设置

在 [mysqld]下边加上

复制代码
# mysql-bin 是日志的基本名或前缀名,最后生成的日志文件是mysql-bin.000001类似,重启mysql数字会递增
log_bin=mysql-bin
#binlog格式,statement,row,mixed可按需选择
binlog-format=ROW
#过期时间
expire_logs_days = 10

如图:

然后重启mysql服务

  1. 查看mysql是否开启了binlog日志,如果开启了才能够通过binlog日志恢复误删

    show variables like '%log_bin%';

  1. 查看二进制日志文件多久过期,如果value是0则没有自动过期时间

  2. 查询binlog日志文件列表

    SHOW BINARY LOGS;

  1. 以binlog.000002为例,查询到误操作的pos值,info值是误操作

  2. 使用mysql的binlog工具解析binlog,并输出为SQL语句,在mysql的data文件夹下cmd命令,执行以下语句:

    mysqlbinlog --start-position=4 --stop-position=2353 ./binlog.000002 > rollback.sql

start-position是上图pos最开始的值,

stop-position是想要恢复的结束值,

binlog.000002是是日志文件的名称

rollback.sql是将想要恢复的节点数据执行的sql语句,生成为rollback.sql文件

  1. 恢复数据执行命令,执行完成以后输入数据库密码即可:

    mysql -u root -p test <rollback.sql

test是要恢复数据的数据库名称

出现以下输出则为恢复成功

注意:如果误删数据库的话需要在当前连接的本地库下创建对应的库名称(如果是在线数据库,需要在服务器上执行恢复数据库操作)

然后执行以上"3."开始进行恢复误删数据库的操作

相关推荐
像风一样!23 分钟前
MySQL数据库如何实现主从复制
数据库·mysql
大白的编程日记.27 分钟前
【MySQL】数据库表的CURD(二)
android·数据库·mysql
友善的鸡蛋1 小时前
项目中执行SQL报错oracle.jdbc.OracleDatabaseException: ORA-00942: 表或视图不存在
数据库·sql·oracle
The best are water1 小时前
jeesite mybatis添加拦截器,推送指定表的变更数据到其他数据库
数据库·mybatis
api_180079054601 小时前
异步数据采集实践:用 Python/Node.js 构建高并发淘宝商品 API 调用引擎
大数据·开发语言·数据库·数据挖掘·node.js
怕什么真理无穷1 小时前
mysql server 9.4 windows安装教程(sqlyog 下载)
数据库
Olrookie1 小时前
MySQL运维常用SQL
运维·数据库·sql·mysql·dba
数据库生产实战2 小时前
ORACLE 19C ADG环境 如何快速删除1.8TB的分区表?有哪些注意事项?
数据库·oracle
blackorbird2 小时前
使用 Overpass Turbo 查找监控摄像头
运维·服务器·数据库·windows
IT永勇2 小时前
SQLite数据库基本操作
数据库·sqlite·嵌入式开发·增删改查·关系型数据库