找回通过delete误删除的数据,上网搜索解决方法,发现没有一个可以正确找回的,经过摸索,找回了delete删除的数据,希望对大家有所帮助,以下是找回的步骤:
1. 确保oracle登录用户具有dbms_flashback的权限,否则的话不能使用闪回功能。如果有闪回功能,直接看第5步。如果没有,
2. 如果没有闪回功能,我们也可以做个测试,确性闪回功能可以使用。切换sysdba用户登录,执行"grant execute on dbms_flashback to flashtest" 语句(flashtest为oracle登录用户名称)。
3. 创建测试表,插入测试记录SQL> create table test(id number(3));
SQL> insert into test values (1);
SQL> insert into test values(2);
SQL> commit;
4. 删除记录SQL> delete from test where id=1;
SQL> commit;
注意:在执行步骤4或者步骤5之前,等待5分钟。
5. 闪回查询SQL
SQL>select dbms_flashback.get_system_change_number from dual;
GET_SYSTEM_CHANGE_NUMBER
------------------------
30775878
SQL>select * from test as of scn 30775600;
注意:30775600必须要小于30775878,直到查到所丢失的数据。