代码改变世界

PL/SQL重新编译包无反应

2013-07-31 12:12  潇湘隐者  阅读(5083)  评论(0编辑  收藏  举报

  前几天碰到一个有趣的事情:早上同事执行一个包很久没有反应,就中断了执行,发邮件让我帮忙查看具体情况,我用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