本篇内容主要讲解“Oracle中重新编译无效的存储过程是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle中重新编译无效的存储过程是什么”吧!Oracle 中的存储过程在有些情况下会变成失效状态,在 PL/SQL Developer 中该存储过程的图标左上角显示一把小红叉叉。比如储过程所引用的对象失效,dblink 出问题啦都可能引起用到它的存储过程失效。再就我的存储过程经常会变成无效,至今原因都未查明。查询 dba_dependencies 视图可以看到存储过程所引用的对象,再就在 dba_objects 视图中可以看到对象的 created 和 last_ddl_time 时间。上面的那种无效的存储程,只要不是语法上有问题,重新编译一下又是可用的了。总不能每次发现时人工去编译的,所以要实现自动化,有以下两种方法(网上找到的所有的 在Oracle中重新编译所有无效的存储过程 代码排版都很混乱,所以主要是重新整理了):Oracle SQL *Plus 中 – 用 spool 生成脚本文件,然后 @ 调入执行,代码如下:spool ExecCompProc.sqlselect ‘alter procedure ‘||object_name||’ compile;’ from all_objectswhere status = ‘INVALID’ and object_type = ‘PROCEDURE’ AND owner=’UNMI’;spool off@ExecCompProc.sql;写成一个存储过程 – 让这个存储过程在某个时机执行,比如 Job 中,代码如下:
create or replace procedure compile_invalid_procedures( p_owner varchar2 — 所有者名称,即 SCHEMA) as–编译某个用户下的无效存储过程 str_sql varchar2(200);begin for invalid_procedures in (select object_name from all_objects where status = ‘INVALID’ and object_type = ‘PROCEDURE’ and owner=upper(p_owner)) loop str_sql := ‘alter procedure ‘ ||invalid_procedures.object_name || ‘ compile’; begin execute immediate str_sql; exception –When Others Then Null; when OTHERS Then dbms_output.put_line(sqlerrm); end; end loop;end;object_type 有哪些可用 select distinct object_type from all_objects 获取到;alter 的语句写法参考下面:到此,相信大家对“Oracle中重新编译无效的存储免费云主机域名过程是什么”有了更深的了解,不妨来实际操作一番吧!这里是百云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
学习下lsof命令lsof全名list opened files,也就是列举系统中已经被打开的文件。我们都知道,linux环境中,任何事物都是文件,设备是文件,目录是文件,甚至sockets也是文件。所以,用好lsof命令,对日常的linux管理非常有帮助。l…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。