作者:天和网-嫣然 | 来源:互联网 | 2023-05-18 20:26
今天在编译一个存储过程的时候,plsql一直未响应(没有其他会话调用,自己也没有调用),任务管理器都结束了好几次进程,但是每次重新进还是一编译就未响应,用下面语句把一些锁住的都杀了,语句如
今天在编译一个存储过程的时候,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了,虽然我还没搞清为啥,但是先记下来,下次再研究研究