我在V$log_History 中只看到整个归档的first_SCN 和next_scn 知道提交时间我想看具体某个commit的SCN号该怎么做??拜谢中
 

解决方案 »

  1.   

    我就是想通过SCN号来进行不完全恢复...现在就是不知道怎么找出误操作的SCN号~~~谢谢了
      

  2.   

    删除记录SQL> execute dbms_flashback.disable; 
    SQL> insert into rec_date select sysdate from dual; 
    SQL> commit; 
    SQL> delete from test where id=1; 
    SQL> commit;    通过以上的操作,我们插入了两条记录,并删除了其中一条记录。在以下的操作中,我们将通过flashback query找到删除的记录
    闪回查询SQL> DECLARE 
    Restore_scn date; 
    BEGIN 
    Select date_scn into restore_scn from rec_date; 
    Dbms_flashback.enable_at_time (restore_scn); 
    END; 
    SQL> select * from test; 
    ID
    1
    2   可以看出,虽然删除记录并提交,但是通过闪回操作,仍能查询到删除前的两条记录。需要注意Oracle每5分钟记录一次SCN,并将SCN和对应时间的映射进行纪录。如果原来插入的记录到做闪回操作的时间在5分钟之内,用基于时间的闪回查询可能得不到记录,因为基于时间点的查询实际上是转化为最近的一次SCN,然后从这个SCN开始进行恢复。因此,如果需要精确的查询可以采用基于SCN的闪回查询,可精确闪回到需要恢复的时间。可以通过DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER语句获取SCN。
      

  3.   

    select DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER as RS from dual得到当前的scn号。flashback table lineitem to scn 123用于恢复。。