Oracle数据库恢复delete误删且已提交的数据

SQL语句测试时,不小心把表中数据全删除了怎么办?

不要慌,不要急,不声不响的恢复就可以了

首先看一下下面的SQL截图,这是我的操作
在这里插入图片描述

恢复数据的方式有很多种,这里列出两种,我采用的是第一种

第一种:通过时间恢复删除且已提交的数据

查询当前系统时间

select to_char (sysdate,'yyy-mm-dd hh24:mi:ss') from dual;

1.首先开启行移动功能(不开启的话,恢复数据的时候可能会报错)

alter table table_name enable row movement;

2.查询删除数据的时间点的数据(确定一下已删除的数据是否存在,不存在的话把时间往前推,再试试)

select * from table_name as times

3.恢复删除且已提交的数据

flashback table table_name to timestamp to_timestamp('2020-12-23 14:58:09','yyyy-mm-dd hh24:mi:ss');

4.关闭行移动功能(一定要记得关闭此功能)

alter table table_name disable row movement;

第二种:通过scn恢复删除且已提交的数据

1.获得当前数据库的scn号(切换到sys用户或system用户查询)

select current_scn from v$database;

2.查询当前scn号之前的scn(确定删除的数据是否存在,如果存在,则恢复数据,如果不存在,则继续缩小scn号)

select * from table_name as of scn 1499220;

3.恢复删除且已提交的数据

flashback table table_name to scn 1499220;

啊~~ 多么痛的领悟!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值