Oracle报错记录被另外一个用户锁定的解决方案
原因
当一个用户对数据进行修改时,若没有进行提交或者回滚,Oracle不允许其他用户修改该条数据,在这种情况下修改,就会出现:“记录被另外一个用户锁定”错误。
解决
查询用户、数据库锁、以及类型等
select object_id,session_id,locked_mode from v$locked_object;
或者
select t2.owner,t2.object_name,t1.session_id,t1.locked_mode from v$locked_object t1, dba_objects t2 where t2.object_id=t1.object_id
结果如下:(用户:HRXT;操作表:HRSA_RESERVES_STAFF;锁编号:1026;锁类型:3)

查询对应的serial和sid,用来kill掉会话进程
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;
结果如:

kill掉该会话进程
alter system kill session 'sid,serial#'
本案例中kill进程语句为:
alter system kill session '1026,14490'
到这里,就可以解决“记录被另外一个用户锁定”错误,如果出现如下图错误:

说明你的权限不足,请用管理员账号登入数据库再重新1,2,3步骤,或者联系数据库管理员赋予你相关权限。
总结
到此这篇关于Oracle报错记录被另外一个用户锁定的解决方案的文章就介绍到这了,更多相关Oracle报错用户锁定内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
oracle下巧用bulk collect实现cursor批量fetch的sql语句
oracle下巧用bulk collect实现cursor批量fetch的sql语句,使用oracel的朋友可以试试了2008-03-03
ORACLE分区表转换在线重定义DBMS_REDEFINITION
这篇文章主要为大家介绍了ORACLE分区表转换在线重定义DBMS_REDEFINITION表,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-07-07
VMware中linux环境下oracle安装图文教程(一)
刚刚接触ORACLE的人来说,从那里学,如何学,有那些工具可以使用,应该执行什么操作,一定回感到无助。所以在学习使用ORACLE之前,首先来安装一下ORACLE 10g,在来掌握其基本工具。俗话说的好:工欲善其事,必先利其器。作为一个新手,我们还是先在VMware虚拟机里安装吧。2014-08-08


最新评论