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重新编译包无反应的主要内容,如果未能解决你的问题,请参考以下文章