首页  >  文章  >  数据库  >  oracle被锁定的记录解锁?

oracle被锁定的记录解锁?

WBOY
WBOY原创
2016-06-07 15:13:22891浏览

Oracal数据库中的一个表的一条记录被锁定,既不能修改也不能删除(只看到沙漏,等一个小时都是这样),删除表对象也不行,报错: ORA_00054:资源正忙,要求指定NOWAIT 解决方法: 1、当前session中commit、rollback都可以解锁 2、在别的session中(DBA)通过

Oracal数据库中的一个表的一条记录被锁定,既不能修改也不能删除(只看到沙漏,等一个小时都是这样),删除表对象也不行,报错:  
  ORA_00054:资源正忙,要求指定NOWAIT  

 

 

解决方法:

1、当前session中commit、rollback都可以解锁  
  2、在别的session中(DBA)通过  
  查找用户锁  
  select   s.username,  
  decode(l.type,'TM','TABLE   LOCK',  
                              'TX','ROW   LOCK',  
                              NULL)   LOCK_LEVEL,  
  o.owner,o.object_name,o.object_type,  
  s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser  
  from   v$session   s,v$lock   l,dba_objects   o  
  where   s.sid=l.sid  
  and   o.object_id=l.id1  
  and   s.username   is   not   null  
  检查出来谁锁了该表  
  查看结果中object_name='你的表名'  
  然后得到sid,serial#  
  alter   system   kill   session   'sid,   serial#'    
  or  
  alter   system   disconnect   session   'sid,   serial#'   immediate;  
  3、select   *   from   table   for   update   nowait可以指定nowait

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn