oracle报 ORA-00054
来源:互联网 发布:阿里巴巴网络推广 编辑:程序博客网 时间:2024/05/31 19:37
oracle之报错:ORA-00054: 资源正忙,要求指定 NOWAIT
问题如下:
SQL> conn scott/tiger@vm_database
Connected to Oracle Database 11g Enterprise Edition Release 11.1.0.6.0
Connected as scott
。。。。。。
SQL> drop table student2;
drop table student2
ORA-00054: 资源正忙, 但指定以 NOWAIT 方式获取资源, 或者超时失效
=========================================================
解决方法如下:
=========================================================
SQL> select session_id from v$locked_object;
SESSION_ID
----------
142
SQL> SELECT sid, serial#, username, osuser FROM v$session where sid = 142;
SID SERIAL# USERNAME OSUSER
---------- ---------- ------------------------------ ------------------------------
142 38 SCOTT LILWEN
SQL> ALTER SYSTEM KILL SESSION '142,38';
System altered
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
- oracle报 ORA-00054
- oracle报错ora-01830
- Oracle报 ORA-00054资源正忙的解决办法
- Oracle报 ORA-00054资源正忙的解决办法
- Oracle 报错:ORA-00313、ORA-00312、ORA-27047 解决方法
- Oracle rebuild index 报 ORA-01652 解决办法
- Oracle rebuild index 报 ORA-01652 解决办法
- oracle创建视图报ora-01031
- plsql 连接 oracle 报错:ora-12514
- 创建oracle实例报错ora-28056
- 启动Oracle报错ORA-00821
- navicat连接oracle报错ora-28547
- ORA-00600 oracle启动报错
- oracle修改字段报错:ORA-22858
- ORACLE报错:ora-12899 拒接行
- Oracle执行CreateTableAs报ORA-600错误
- Oracle数据库报ora-28547错误解决方案
- c# 连接Oracle报错 ORA-00162
- Kotlin-40.kotlin调用Java之二(Call Java from Kotlin)
- 【PAT】【Advanced Level】1009. Product of Polynomials (25)
- 欢迎使用CSDN-markdown编辑器
- JAVA系列课程讲座二:使用Socket通信实现简单聊天通信程序(UDP方式)
- java NIO(二)
- oracle报 ORA-00054
- HTC Vive VR房产项目开发一(手柄提示+户型图)
- 美滋滋,想想第四天了都激动,滋滋~~ 今天上js了(╯‵□′)╯︵┻━┻
- 《ImageNet Classification with Deep Convolutional Neural Networks》(AlexNet)论文翻译
- JSP技术基础概念
- Laravel基础-模板的引入方式
- 白话空间统计之二十五:空间权重矩阵(二)
- 湖南中医药大学2017年集训队第四场选拔赛-Problem B: Power Eggs
- 从一组字符串中取出数字