zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    winform 关于Messagebox自动定时关闭
    Git常用命令
    使用消息队列异步化系统
    在Servlet(或者Filter,或者Listener)中使用spring的IOC容器
    基于Annotation与SpringAOP的缓存简单解决方案
    Ant自动构建
    Quartz定时调度
    Sybase数据库的分页功能
    oracle 日期相减
    n个List<Map>合并,Map中某属性值相等的value值相加
  • 原文地址:https://www.cnblogs.com/zhangyingai/p/7082492.html
Copyright © 2011-2022 走看看