首頁 > 資料庫 > mysql教程 > oracle被锁定的记录解锁?

oracle被锁定的记录解锁?

WBOY
發布: 2016-06-07 15:13:22
原創
967 人瀏覽過

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板