MySQL binlog反解析

反解析delete语句

背景:delete table忘了加条件导致整张表被删除
恢复方式:直接从binlog里反解析delete语句为insert进行恢复

导出删指定表的DELETE语句:

# mysqlbinlog  -vv -d dbname mysql-bin.000048 | awk '/DELETE FROM/ && (/dbname.tbname/ || /\`dbname\`.\`tbname\`/){
    while(1){
        print $0;
        getline;
        if($0 !~ /^###/){
            break;
        };
    }
}' > dbname.tbname.delete.txt

去掉binlog每行开头的#

# sed -i 's/^### //g' dbname.tbname.delete.txt

语句转换 DELETE --> INSERT

# sed -i "s/^DELETE FROM/INSERT INTO/g" dbname.tbname.delete.txt
# sed -i "s/^WHERE/VALUES(/g" dbname.tbname.delete.txt
# sed -i '/@13=.*/a );' dbname.tbname.delete.txt

字段处理

# cat dbname.tbname.delete.txt | awk -F"=|/*" '{
    if($0 ~ /^INSERT|^VALUES|^);/){
        print $0;
    }else{
        printf $2",";
    };
}' > dbname.tbname.insert.sql

去掉values()最后一个逗号

# sed -i "s/,);$/);/g" dbname.tbname.insert.sql

至此就将delete语句反解析为insert语句了

重新导入数据库

posted @   wshenJin  阅读(1770)  评论(4编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
历史上的今天:
2018-08-28 Docker 容器
点击右上角即可分享
微信分享提示