编译无效的oracle程序

Cas*_*sey 2 oracle plsql oracle11g

我有一个包装程序(proc_main)调用其中的一些程序.

create or replace Procedure proc_main
as
begin

proc_child1;

proc_child2;

proc_child3;

proc_compile_invalids; -- This invokes "alter procedure <procedure_name> compile" statement for all the invalids.

end;
/
Run Code Online (Sandbox Code Playgroud)

proc_child过程应用一些处理逻辑,其中包含一些重命名表的步骤.

这使程序无效,这就是为什么我有proc_compile_invalids过程再次将它们设置为有效状态的原因.

我的问题是:当我执行proc_main过程时,它会使主程序和内部子程序无效.因此,当proc_compile_invalids作为最后一步被调用时,它会在尝试重新编译主调用过程时挂起.

显然,如果我删除最后一步并单独执行它不是问题.

我知道我可以通过注释编译过程并将其作为独立执行来将它们分成2个不同的调用.而且我也知道这是一个美化步骤,因为oracle会在下次执行之前尝试编译一个过程.所以,无论如何,残疾人变得有效.但是,在当天执行结束时,他们都处于无效状态,如果可以避免,我会受到权力的质疑!

所以,只是想知道我是否可以避免分离调用并仍然将其保留为主过程的最后一步.

任何想法/指针都非常感激.

Vin*_*rat 6

您可以使用动态SQL来破坏依赖关系:

CREATE OR REPLACE PROCEDURE proc_main AS
BEGIN

   EXECUTE IMMEDIATE 'BEGIN proc_child1; END;';

   EXECUTE IMMEDIATE 'BEGIN proc_child2; END;';

   EXECUTE IMMEDIATE 'BEGIN proc_child3; END;';

   proc_compile_invalids;  -- This invokes 
                           -- "alter procedure <procedure_name> compile" 
                           -- statement for all the invalids.

END;
Run Code Online (Sandbox Code Playgroud)