phpmyadmin误删表后使用二进制恢复表的方法

在用phpmyadmin删除测试数据时,竟然将整个表删除了:

等程序运行出错时,才出现整个表都没有了,而且之前也没有备份好!

服务器是linux的,我不是很熟悉,也不知道mysql装在哪。

我在phpmyadmin中看到了这个:

脑里出来了google上说的用二进制恢复,就点开看一下。结果大喜!OMG,服务器开通了日志!

里面有数据库的操作日志,而且还是sql格式的!!!

我之前没有接触过这个东西,但这时它就是我的救命稻草。

我浏览了一下,里面有近一个月的更新记录,已经足够了。不过有一个问题,在phpmyadmin里面看,只能显示其中一小部份内容,面对10几w的数据行,想要一个个找出被删表的数据,太难了。

这时,我想到了可以从服务器中下载这些文件,然后得到其中的数据。

说干就干,我登录服务器,搜索这些二进制文件:

上图中红圈的就是了

然后将这些文件一个个导出成可以阅读的sql:

这样将这些二进制文件一个个输出成了正常的sql文件。

这时,就是要从这些文件中找到被删表相关的数据了,于是我写了个java程序帮我做这个事情:

复制代码

代码如下:

package com.nerve.sql.reload;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.util.ArrayList;
import java.util.List;

import org.nerve.util.NumberUtil;

/**
* @project: cloudOffice_swing
* @file: ReloadWorker.java
* @package: com.nerve.sql.reload
* @description:
* 将二进制日志导出的文件中相应表的操作记录提出出来
* @author: 集成显卡 <a href="mailto:1053214511@qq.com">1053214511@qq.com</a>
* @date&time: Jan 23, 2014
* @change log:
*/
public class ReloadWorker {

public void read(List<String> orgF, String targetF, String table) throws Exception{
BufferedWriter bw = new BufferedWriter(new FileWriter(targetF, true));

for(String or:orgF){
BufferedReader br = new BufferedReader(new FileReader(or));
String t = null;
String t2 = null;
table = table.toUpperCase();
while((t=br.readLine())!=null){
t2 = t.toUpperCase();
/*
* 如果是update操作,直接提出
*/
if(t2.startsWith("UPDATE "+table)){
bw.append(t+";/n");
}
/*
* 如果是insert语句,因为有一些旧服务器的数据
* 所以要先执行delete操作
*/
else if(t2.startsWith("INSERT INTO "+table)){
String ids = t2.substring(t2.lastIndexOf(","));
bw.append("delete from "+table+" where id="+NumberUtil.toDigital(ids)+";/n");
bw.append(t+";/n");
}
/*
* sql语句后面都要加 ; ,因为原来没有,不加的话,在导入到数据库时,出错
*/
}
br.close();
}

bw.flush();
bw.close();
}

public static void main(String[] args) throws Exception{
long sd = System.currentTimeMillis();
ReloadWorker w = new ReloadWorker();
List<String> orgs = new ArrayList<String>();
orgs.add("C:/Users/IBM_ADMIN/Desktop/000015.txt");
orgs.add("C:/Users/IBM_ADMIN/Desktop/000016.txt");
orgs.add("C:/Users/IBM_ADMIN/Desktop/000017.txt");
orgs.add("C:/Users/IBM_ADMIN/Desktop/000018.txt");
orgs.add("C:/Users/IBM_ADMIN/Desktop/000019.txt");

String targetS = "C:/Users/IBM_ADMIN/Desktop/000017_sql.txt";
w.read(orgs, targetS, "task");

System.out.println("DONE, on " +(System.currentTimeMillis() - sd)/1000+" s");
}
}

得到了汇总的sql文件后,就导入到数据库中。

最后,出一个运行图:

终于松了一口气。

(0)

相关推荐

  • 手机微信误删的聊天记录如何找回恢复

    微信聊天后,会产生大量的聊天记录,平时也许用不到,手残删掉了,关键时刻想要查询却不知道该怎么办了?今天就跟大家介绍三种微信误删的聊天记录如何找回恢复的解决方法.方法一.电脑端微信备份恢复1. 这个方法 ...

  • excel2010复制粘贴到新表后字体背景变色原因

    在用excel2010时,从一个工作表向另一个工作表中复制粘贴数据后,有时会出现字体或者背景颜色改变的情况.这种情况的原因之一是工作表中设置了条件格式.这里介绍如何查看,取消条件格式,以供参考. 操作 ...

  • excel2003工作表变成灰色如何恢复正常?

    excel工作表变成了灰色了,怎么办呢,如何恢复正常?小编在这里分享下有关这方面的小.或许可以帮到一些朋友. 操作方法 01 全选工作表后,把行高误操作设置为"0"时,工作表就会呈 ...

  • 百度卫士清理注册表后系统出现异常怎么办?

    一些网友通过百度卫士的系统清理功能清理了一些注册表,但是,系统却因此出现了异常.遇到这个状况该怎么办呢?一起来走进今天的百度卫士使用教程,看看我们的建议吧! 百度卫士 如果您通过百度卫士的清理注册表后 ...

  • win10预览版修改注册表后无法升级解决办法

    win10预览版修改注册表后无法升级怎么办?有部分网友遇到win10预览版修改注册表后无法升级的问题.对此,微软相关负责人给出了win10预览版修改注册表后无法升级解决办法,一起来看看吧! 去年10月 ...

  • 如何能使修改注册表后立即生效

    方法一:修改完之后,按F5刷新--关闭注册表编辑器--按Ctrl+Alt+Del调出任务管理器--结束explorer.exe(同EXPLORER.EXE)进程,图标.任务栏消失--不要关闭任务管理器 ...

  • 如何彻底删除激活office后残留的注册表提示0xC004F074

    有的小伙伴在电脑上安装了Office软件,想要激活office软件时,发现因为卸载软件不彻底,所以残留的注册表大大影响了Office软件的再次激活,这时候就想要彻底删除激活office后残留的注册表, ...

  • WPS中误删的表格中的工作表怎么找回

    今天给大家介绍一下WPS中误删的表格中的工作表怎么找回的具体操作步骤.1. 首先我们打开一个WPS表格,以便于演示.2. 如图,在打开的表格中,可以看到有两个sheet.3. 然后我们在sheet2上 ...

  • 手机照片误删后怎么恢复?恢复照片的方法

    手机照片误删后怎么恢复?每个人都有误删手机照片的经历,有什么方法可以恢复误删的照片呢?给大家分享恢复照片的方法. 在"最近删除"里恢复 01 现在很多安卓手机相册都有"最 ...