当前位置:首页 > 开发 > 数据库 > 正文

ora-00054:resource busy and acquire with nowait specified解决方法

发表于: 2014-03-29   作者:bijian1013   来源:转载   浏览:
摘要:         当某个数据库用户在数据库中插入、更新、删除一个表的数据,或者增加一个表的主键时或者表的索引时,常常会出现ora-00054:resource busy and acquire with nowait specified这样的错误。主要是因为有事务正在执行(或者事务已经被锁),所有导致执行不成功。 1.下面的语句

        当某个数据库用户在数据库中插入、更新、删除一个表的数据,或者增加一个表的主键时或者表的索引时,常常会出现ora-00054:resource busy and acquire with nowait specified这样的错误。主要是因为有事务正在执行(或者事务已经被锁),所有导致执行不成功。

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的管理控制台来执行。

 

如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放。
即对数据表进行创建索引之类的操作时,提示:ORA-00031: session marked for kill错误信息,那么可以在OS一级再杀死相应的进程(线程)

3.首先执行下面的语句获得进程(线程)号:

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

ora-00054:resource busy and acquire with nowait specified解决方法

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
一、情况一 抽象出问题是这样的: class DLL_API1 A { func() { vector vec; B b; b.func(vec); ret
Resource 由于最近经常用到ASCII码表和键盘扫描码表,所以就把它贴上来,用的时候发方便一些。也希
今天自定义了一个AlertDialog对话框,第一次点击时正常,但第二次调用时会出现错误:java.lang.Ille
好久不看大片了,今天花了一些时间仔细看了一遍《肖申克的救赎》,应该是很仔细的看了一遍,这个影片
好久不看大片了,今天花了一些时间仔细看了一遍《肖申克的救赎》,应该是很仔细的看了一遍,这个影片
什么是buffer busy wait? A session that reads or modifies a buffer in the SGA must first acqui
在考虑双口RAM的读写冲突问题时,决定使用双口RAM CY7C131的BUSY信号线来对FT2232H的MCU Host Bus进
一.for update 和 for update nowait 的区别 首先一点,如果只是select 的话,Oracle是不会加任何锁
FOR UPDATE NOWAIT BEGIN SELECT x FROM table FOR UPDATE NOWAIT; EXCEPTION WHEN OTHERS THEN <
一.for update 和 for update nowait 的区别 首先一点,如果只是select 的话,Oracle是不会加任何锁
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号