存储过程编译时会卡死

Oracle存储过程编译卡死

  解决方法如下:

  1:查V$DB_OBJECT_CACHE

  SELECT * FROM V$DB_OBJECT_CACHE WHERE name='CRM_LASTCHGINFO_DAY' AND LOCKS!='0';

  注意:CRM_LASTCHGINFO_DAY为存储过程的名称。

  发现locks=2,

  2:按对象查出sid的值

  select /*+ rule*/  SID from V$ACCESS WHERE object='CRM_LASTCHGINFO_DAY';

  注意:CRM_LASTCHGINFO_DAY为存储过程的名称。

  3:查sid,serial#

  SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='刚才查到的SID';

  4:alter system kill session 'sid值,serial#值' immediate;

posted @ 2015-07-20 10:33  update_  阅读(839)  评论(0编辑  收藏  举报