zoukankan      html  css  js  c++  java
  • 恢复误删的DB table数据

    由于一时手误输入了 DELETE FROM TABLE WHERE age REGEXP 'd';导致这个表的数据被删除

    解决方法:

    登录mysql,查看目前的binlog文件

    mysql> show master status;
    +---------------+----------+--------------+------------------+-------------------+
    | File          | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +---------------+----------+--------------+------------------+-------------------+
    | binlog.000016 |    16895 |              |                  |                   |
    +---------------+----------+--------------+------------------+-------------------+

    将日志复制到.sql文件    添加--base64-output=decode-rows 参数导出的sql文件里不包含数据部分(即insert,delete,update),主要是方便分析,实际导出的 sql是不能加这个参数的

    mysqlbinlog --no-defaults --base64-output=decode-rows binlog.000016 > 20190322.sql

     # at 12731
     823 #190321 18:54:17 server id 1  end_log_pos 12810 CRC32 0xa49cda19        Anonymous_GTID  last_committed=47       sequence_number=48      rb     r_only=yes    original_committed_timestamp=1553165658210230   immediate_commit_timestamp=1553165658210230     transaction_length=333

    将日志复制到.sql文件

    mysqlbinlog --no-defaults binlog.000016 > 20190322.sql

    从at 12731开始恢复

    mysqlbinlog --start-position=219 --stop-position=12731 binlog.000016 > ./recovery-restore.sql
    mysql -uroot -p gc < recovery-restore.sql
  • 相关阅读:
    服务器带宽
    nload 源码安装
    Error: rpmdb open failed
    宽带,带宽,网速
    使用speedtest-cli测量服务器带宽
    ubuntu 安装 iperf
    微信退款机制
    记录程序执行之间,接口调用时间到日志文件或数据库
    机智的查询
    如果一些复杂的数据查询不好用数组,那就用字符串拼接,灵活方便
  • 原文地址:https://www.cnblogs.com/jiangfeilong/p/10579609.html
Copyright © 2011-2022 走看看