应用场景

在查询oracle表时,提示表记录被另一个用户锁住了

有可能是在使用了pl/sql工具后修改某个表记录时,加锁,或者发生故障异常退出,下次登录进去修改不了

查询锁

--查看数据库的锁的来源、类型等
select t.object_id, t.session_id, t.locked_mode from v$locked_object ;

查询锁与session连接

--查询 锁与session连接 用户名、serial#、时间
select s.username, s.sid, s.serial#, s.logon_time
from v$locked_object o, v$session s
where o.session_id = s.sid
order by s.logon_time ;

查询数据库 锁的session 的sid、serial# 杀死此次连接session

杀死连接session

-- 找到锁的连接 session 的sid、serial# 用于杀死session连接
alter system kill session 'sid,serial#' ; -- 列如 sid=642 serial#=10439
alter system kill session '642,10439' ;

本人是由于使用了 select * from tableName for update ,后进行修改,然后pl/sql 就异常退出了

下次登录进去后,发现无法修改,报错提示:表记录被另一个用户锁住

用此方法可以实现解锁,本人亲测有效

05-11 22:07