下面是我在开发中遇到的一个问题,通过以下的方法很好的解决了,下面部分是我从别的网页中摘下来的,以防自己忘记。
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