加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

用flashback恢复存储过程

发布时间:2020-12-15 06:28:49 所属栏目:百科 来源:网络整理
导读:今天一个朋友问我,删除了一个存储过程是否可以恢复,想了想,恢复存储过程就相当于找到删除过程前SOURCE$表的数据,可以用flashback功能恢复。 下面的测试过程。 首先建立存储过程: SQL create or replace procedure p_test is 2 begin 3 null; 4 end p_te

今天一个朋友问我,删除了一个存储过程是否可以恢复,想了想,恢复存储过程就相当于找到删除过程前SOURCE$表的数据,可以用flashback功能恢复。
下面的测试过程。


首先建立存储过程:
SQL> create or replace procedure p_test is
2 begin
3 null;
4 end p_test;
5 /

Procedure created

SQL> col sysdate format a20
SQL> select sysdate from dual;

SYSDATE
--------------------
2007-7-10 23:50:32

SQL> drop procedure p_test;

Procedure dropped

要恢复存储过程首先需要知道该过程在删除前对应的OBJECT_ID,这个同样也可以用flashback得到。

SQL> SELECT obj# FROM obj$ AS OF TIMESTAMP TO_TIMESTAMP('2007-7-10 23:50:32','YYYY-MM-DD HH24:MI:SS') WHERE NAME='P_TEST';

OBJ#
----------
7346

在实际中,为了更精确得到OBJ#,可能还需要限制所属用户等条件。

要恢复过程,时间就是恢复SOURCE$表在过程被删除前的数据,这个用flashback是可以轻松做到的:
SQL> SELECT * FROM source$ AS OF TIMESTAMP TO_TIMESTAMP('2007-7-10 23:50:32','YYYY-MM-DD HH24:MI:SS') where obj#=7346 order by line;

OBJ# LINE SOURCE
---------- ---------- --------------------------------------------------------------------------------
7346 1 procedure p_test is
7346 2 begin
7346 3 dbms_lock.sleep(60);
7346 4 Insert Into x Values(1);
7346 5 Commit;
7346 6 end p_test;

6 rows selected

从上面结果可以看到,存储过程已经恢复。
注意:
1、flashback是9i后才引起的,之前版本不能用这个方法恢复
2、从删除到恢复时的时间间隔不能超过undo_retention的设定值

转载出处:http://space6212.itpub.net/post/12157/306512

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读