mysql 找回误删表的数据方法找回误删表的数据方法(必看必看)
有备份的话很简单,只需要生成一个最近备份的数据 然后用mysqlbinlog找回备份时间点之后的数据 再恢复到现网即可。
要是没有备份 可能就会比较麻烦,找回数据的成本也是非常之高的.
下面介绍下下面介绍下 mysqlbinlog找回备份时间点之后的数据的办法:找回备份时间点之后的数据的办法:
做个简单的实验,将mysql的表数据删除之后,然后用mysqlbinlog 找回刚才删除的表的数据。
app表的创建时间和数据的插入: 2013-02-04 10:00:00
原理: mysqlbinlog
前提: mysql开启了bin log日志
测试删除之前:测试删除之前:
mysql> show tables;
+-----------------------+
| Tables_in_report_sina |
+-----------------------+
| app |
| test |
+-----------------------+
mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2013-02-04 11:45:44 |
+---------------------+
1 row in set (0.01 sec)
mysql> select count(1) from app;
+----------+
| count(1) |
+----------+
| 10 |
+----------+
1 row in set (0.01 sec)
开始删除数据:开始删除数据:
mysql> delete from app where id =1;
Query OK, 1 row affected (0.00 sec)
mysql>
mysql> delete from app where id <6;
Query OK, 4 rows affected (0.01 sec)
mysql> select count(1) from app;
+----------+
| count(1) |
+----------+
| 5 |
+----------+
1 row in set (0.00 sec)
mysql> select now();
+---------------------+
| now() |
+---------------------+
| 2013-02-04 12:08:45 |
+---------------------+
开始找回数据:开始找回数据:
1.找到bin log的位置: