PL/SQL重新编译包无反应

Posted 张英爱

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PL/SQL重新编译包无反应相关的知识,希望对你有一定的参考价值。

  前几天碰到一个有趣的事情:早上同事执行一个包很久没有反应,就中断了执行,发邮件让我帮忙查看具体情况,我用PL/SQL Developer登录后,找到这个包的过程中发现这个包的图标有红色叉叉,也就是说这个包有地方没有编译通过,于是我便单击右键点击“重新编译”,结果一直没有响应,导致PL/SQL Developer直接卡死,刚开始没太留意,直接杀掉PL/SQL Developer相关进程,重新打开它然后编译这个包,结果还是这个情况,还是头一次遇到这种情况,一头雾水. 后来搜索了一下才知道原因:

  1:当包正在被调用执行时,编译该包会导致无响应情况。 
  2:包中的对象或依赖对象被其它session所拥有。

查看包体是否被其它用户调用正在执行,以sys身份登录,执行下面SQL查询

SELECT DISTINCT ‘(‘ || s.sid || ‘) - ‘ || username AS "(session) - username"     
FROM V$SESSION s, sys.x$kglob o, sys.x$kglpn p   
WHERE upper(o.kglnaobj) LIKE upper(‘%不能编译的包体%‘)      
     AND p.kglpnhdl = o.kglhdadr      
  AND s.SADDR = p.kglpnuse;

发现该包没有正在running,然后查看被锁的对象中是否有该包依赖的对象,结果发现包中某个表被某个会话给锁住了。杀掉该进程后,重新编译该包,问题解决了。

参考资料: 
http://blog.csdn.net/robinson_0612/article/details/7616923







以上是关于PL/SQL重新编译包无反应的主要内容,如果未能解决你的问题,请参考以下文章

PL/SQL 编译失败,没有错误消息

pl/sql编译存储过程卡住的解决方法

在重新编译oracle包时,哪些缓存会更新?

查看package编译时的错误信息及重新编译

在哪里保存 PL/SQL 常量?

如何找到Oracle Forms接口集成的PL/SQL程序