编译存储过程时一直遇到未响应 ORA-04021: 等待锁定对象 时发生超时

  今天在编译一个存储过程的时候,pl/sql一直未响应(没有其他会话调用,自己也没有调用),任务管理器都结束了好几次进程,但是每次重新进还是一编译就未响应,用下面语句把一些锁住的都杀了,语句如下:

select V$SESSION.*
  from v$lock,
       V$SESSION
 where v$lock.sid = v$session.sid
   and V$SESSION.MACHINE = 'pc-PC';

将查出的用语句:alter system killsession   '206,10352';   -----‘SID,SERIAL#


但是全部杀完之后,再去编译还是未响应,这下我就郁闷了,没有DBA权限,超级无语

首先用自己的机器去查还有哪些不是lock的

select V$SESSION.* from V$SESSION where V$SESSION.MACHINE = 'pc-PC';

然后又捣鼓了好久,在命令窗口编译我的存储过程,等了很久报了一个错ORA-04021: 等待锁定对象  时发生超时

然后用语句:

select b.serial#, a.*
  from v$session_wait a, v$session b
 where a.sid = b.sid;

这个后面加一句and b.sid=‘刚才查出的一些sid’

然后 alter system kill session '110,23002'; -----‘SID,SERIAL#


最后再次编译的时候,就OK了,虽然我还没搞清为啥,但是先记下来,下次再研究研究

展开阅读全文

没有更多推荐了,返回首页