我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL实现基于时间点的恢复

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL实现基于时间点的恢复

前期说明:我每天指定了数据库凌晨1点做全备,这天有人一不小心,删除了某个数据库里面的一个表,需要恢复,怎么弄? 


参考 :http://blog.csdn.net/zhaoyangjian724/article/details/48715321


1  确认log_bin是否打开 

mysql> show global variables like 'log_bin'; 
+---------------+-------+ 
| Variable_name | Value | 
+---------------+-------+ 
| log_bin       | ON    | 
+---------------+-------+ 
1 row in set (0.00 sec)

 

如果没有开启在配置文件里my.cnf,添加

[mysqld]

log-bin=mysql-bin

2  在test库里面新建一个表upl

use test;
create table upl;
插入数据
insert into upl values (1,'tom'),(2,'mary'),(3,'bean');
查看数据
mysql> select * from upl;
+------+------+
| id   | user |
+------+------+
|    1 | tom  |
|    2 | mary |
|    3 | bean

3 在时间点a备份数据库test

mysqldump -uroot -p --databases test > /data/test.sql


4 时间点b再次登录数据库,创建表test.t2

 mysql> create table t2 (a int); 
Query OK, 0 rows affected (0.00 sec) 
mysql> insert into t2 values(10); 
Query OK, 1 row affected (0.02 sec) 
mysql> commit; 
Query OK, 0 rows affected (0.00 sec) 
mysql> select * from t2; 
+------+ 
| a    | 
+------+ 
|   10 | 
+------+ 
1 row in set (0.00 sec)

5 在时间点c删除upl,t2

drop table upl;

drop table t2;


6 要求恢复到时间点b (upl和t2同时存在)

先恢复全库  mysql -uroot -p < /data/test.sql

登录mysql发现upl表已经存在了

挖掘log-bin日志  mysqlbinlog --start-datetime='2016-10-21 14:46:10' --stop-datetime='2016-10-21 14:50:35'  mysql-bin.000001 > recovery.sql


说明:这两个时间点只能取大概的时间,不能确定精确的时间,可以写上面数据库备份完的那个时间,结束时间就写删除某个表的时间(大概) 这个mysql-bin.000001 日志文件选择最新的那个(距离删除时间最近的)

然后再把这个recovery.sql倒入到数据库里

mysql -uroot -p < recovery.sql

再次登录mysql数据库,发现t2也已经存在了,到此全部恢复完成!


 


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL实现基于时间点的恢复

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL 基于时间点的快速恢复方案

之所以有这样一篇文章,是因为在前几天的一个晚上,要下班的时候,业务方忽然有一个需求,是需要恢复一个表里面的数据,当时问了下情况,大概是这样的:业务方不小心在一个表里面做了一个update的操作,可能是where条件没有写对,导致表里面的
2022-05-13

基于 MyFlash 的 MySQL 数据恢复

以前mysql回复误删数据用的比较多的是基于原始binlog或binlog2sql,昨天又遇到一例开发误删的问题,这次用用美团开源的工具 MyFlash试试。用下来效果还是不错的,基于库 or 表的过滤可以有效的筛选出来目标sql。 #### 项目地址 ht
2014-07-10

Oracle表空间时间点恢复的方法

目录1.新建表空间2.使用RMAN备份.3.Drop表空间模拟故障4.查看控制文件备份5.找到 pdbprod2 备份之后,最邻近的控制文件备份对应的 SCN6.恢复表空间7.表空间onlijavascriptne已有一个数据库全备,在PD
Oracle表空间时间点恢复的方法
2024-10-04

Mysql数据库中怎么按时间点恢复

Mysql数据库中怎么按时间点恢复,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1. 按时间点恢复的技术实现如果客户在某时间节点由于误操作,导致数据丢失,RDS管控服务是如
2023-06-20

基于OGG实现MySQL实时同步

?????? 哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】!??? 中国DBA联盟(ACDU)成员,目前服务于工业互联网 擅长主流Ora
基于OGG实现MySQL实时同步
2023-12-22

基于 SSL 实现MySQL主从复制

1、主服务器配置1)、在主服务器创建SSL/RSA文件 #在MySQL5.7之后,安装完毕MySQL会在data目录下自动生成,这里模拟没有这些文件 [[email protected] ~]# mysql_ssl_rsa_setup --user=mysql
基于 SSL 实现MySQL主从复制
2016-06-28

MySQL中怎么实现基于时间序列的数据计算

在MySQL中实现基于时间序列的数据计算可以通过使用日期和时间函数以及聚合函数来实现。以下是一些常用的时间序列数据计算方法:计算时间序列数据的平均值:SELECT AVG(data_column) FROM table_name WHE
MySQL中怎么实现基于时间序列的数据计算
2024-04-29

编程热搜

目录