请问被锁定的记录能不能解锁?如何解锁?

时间:2021-08-10 21:41:12
Oracal数据库中的一个表的一条记录被锁定,既不能修改也不能删除(只看到沙漏,等一个小时都是这样),删除表对象也不行,报错:
ORA_00054:资源正忙,要求指定NOWAIT
我记得是因为修改这条记录后,没有commit,接着又再次修改,该记录就被锁死了

因为这是一个临时表,每次做某种处理的时候都要先清空这个表,现在不能做删除,相应的处理也无法进行,已经影响到正常的生产,搞的我头都大了。

请大侠赐教:
1.有没有办法给被锁定的记录解锁?如何解锁?
2.如果不能解锁,有没有办法删除这个表,然后我好重新建立?
  它说“要求指定NOWAIT",可以指定的吗?

谢谢!

3 个解决方案

#1


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
----------------------------------------
一个问题不要问两遍

#2


不好意思,我以为第一次问的没有送出去,就再问了一次

#3


有意思。

#1


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
----------------------------------------
一个问题不要问两遍

#2


不好意思,我以为第一次问的没有送出去,就再问了一次

#3


有意思。