您的位置:首页 > 数据库 > Oracle

oracle提示:ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源, 或者超时失效

2018-02-09 16:25 435 查看
真的是超级暴躁了,刚刚写的博客没有发表成功。。。。。。我特么说了转载了啊。。。。。。。现在写这篇的时候,沉浸在刚刚的暴躁之中,不想说任何话了。但是问题是肯定可以用本文的方法解决的。
原文链接:http://blog.csdn.net/lwei_998/article/details/6077427
问题如标题,我按照原文解决了问题,我的解决方法如下:
a:select session_id from v$locked_object;
查到 session_id 的值
b:SELECT sid, serial#, username, osuser FROM v$session where sid = 28;
sid 的值就是 session_id 的值
c:ALTER SYSTEM KILL SESSION '28,38';
28是sid的值,38是serial#的值

下面是原文整理出来的具体sql语句的含义
1.查询数据库中的锁select * from v$lock;
select * from v$lock where block=1;2.查询被锁的对象select * from v$locked_object;3.查询阻塞查被阻塞的会话
select * from v$lock where lmode=0 and type in ('TM','TX');查阻塞别的会话锁
select * from v$lock where lmode>0 and type in ('TM','TX');4.查询数据库正在等待锁的进程select * from v$session where lockwait is not null;5.查询会话之间锁等待的关系select a.sid holdsid,b.sid waitsid,a.type,a.id1,a.id2,a.ctime from v$lock a,v$lock b
where a.id1=b.id1 and a.id2=b.id2 and a.block=1 and b.block=0;6.查询锁等待事件
select * from v$session_wait where event='enqueue';解决方案:
select session_id from v$locked_object; --首先得到被锁对象的session_id
SELECT sid, serial#, username, osuser FROM v$session where sid = session_id; --通过上面得到的session_id去取得v$session的sid和serial#,然后对该进程进行终止。
ALTER SYSTEM KILL SESSION 'sid,serial';
example:

ALTER SYSTEM KILL SESSION '13, 8';

一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库。现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。 1.下面的语句用来查询哪些对象被锁:select object_name,machine,s.sid,s.serial# 
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;2.下面的语句用来杀死一个进程:
alter system kill session '24,111'; (其中24,111分别是上面查询出的sid,serial#)【注】以上两步,可以通过Oracle的管理控制台来执行。3.如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:
select spid, osuser, s.program 
from v$session s,v$process p
where s.paddr=p.addr and s.sid=24 (24是上面的sid)4.在OS上杀死这个进程(线程):
1)在unix上,用root身份执行命令: 
#kill -9 12345(即第3步查询出的spid)
2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
orakill sid thread
其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即第3步查询出的spid。
例:c:>orakill orcl 12345
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐