Oracle中无效存储过程的重新编译方法

原创|其它|编辑:郝浩|2009-09-07 10:49:18.000|阅读 723 次

概述:本文介绍了Oracle中无效存储过程的重新编译方法。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

  在SQL_PLUS中:

  spool ExecCompProc.sql select 'alter procedure
  '||object_name||' compile;' From all_objects
  where status = 'INVALID' and object_type = 'PROCEDURE';
  spool off @ExecCompProc.Sql;

  整理成一个存储过程:

  Create Or Replace Procedure Zl_Compile_Invalid_Procedure
  AsStrsql Varchar2(200);BeginFor x In (Select Object_Name
  From All_Objects Where Status = 'INVALID'
  And Object_Type = 'PROCEDURE') LoopStrsql := 'Alter
  Procedure ' || x.Object_Name || ' Compile';Begin Execute
  Immediate Strsql; Exception--When Others Then Null;
  When OTHERS Then dbms_output.put_line(Sqlerrm);
  End;End Loop;End;

  最后执行:

  exec Zl_Compile_Invalid_Procedure;

  如果要看到无法重编译的过程的出错信息,需要执行前设置set serverout on。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:IT专家网论坛

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP