PL/SQL中记录被另一个用户锁住的原因及处理方法

如题所述

PL/SQL中记录被另一个用户锁住的原因:另一个用户正在修改或删除该记录。此时其它用户只能做查询,不能进行删改操作。如果要解锁,正在删改操作的用户退出删改状态即可。

因死机或挂起不能退出删改状态时,找到该用户的进程,kill该进程就可以了。实在不行的话重新启动数据库也可以。

处理方法:

1、查看数据库锁,诊断锁的来源及类型:

select object_id,session_id,locked_mode from v$locked_object;

或者用以下命令:

select b.owner,b.object_name,l.session_id,l.locked_mode from v$locked_object l, dba_objects b where b.object_id=l.object_id

2、找出数据库的serial#,以备杀死:

select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1,v$session t2 where t1.session_id=t2.sid order by t2.logon_time;

3、杀死该session:   

alter system kill session 'sid,serial#'

扩展资料

SQL Server中的锁类型及用法:

数据库系统的角度来看:分为独占锁(即排它锁), 共享锁和更新锁。MS-SQL Server使用以下资源锁模式。

锁模式描述:

共享(S)用于不更改或不更新数据的操作(只读操作),如SELECT语句。

更新(U)用于可更新的资源中。防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁

排它(X)用于数据修改操作,例如.INSERT、UPDATE 或DELETE。确保不会同时同一资源进行多重更新。

意向锁用于建立锁的层次结构。意向锁的类型为:意向共享(IS)、意向排它(IX)以及与意向排它共享(SIX)。

架构锁在执行依赖于表架构的操作时使用。架构锁的类型为:架构修改(Sch-M)和架构稳定性(Sch-S)。

大容量更新(BU)向表中大容量复制数据并指定了TABLOCK提示时使用。

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-10-04
被锁的原因就是有人在你之前修改记录,此时oracle会通过事务锁锁住这个记录,而且这个修改记录的人还没有提交或回滚记录,接下来你又试图修改同一条记录,你就会被这个事务锁所阻塞。处理方法很简单,可以有以下两种方法:1. 找到在你之前修改记录的那个人,让他在他的修改记录的会话里做一下commit或rollback2.用sysdba身份登录数据库,执行下面的SQL语句所查出来的命令:select Distinct 'alter system kill session '||chr(39)||b.sid||','||b.serial#||chr(39)||';'As cmd,b.username,b.logon_timefrom v$locked_object a,v$session bwhere a.session_id=b.sid执行cmd字段显示的命令即可。本回答被提问者采纳
相似回答