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;
啊~~ 多么痛的领悟!