Oracle报错记录被另外一个用户锁定的解决方案

时间:2021-05-02

原因

当一个用户对数据进行修改时,若没有进行提交或者回滚,oracle不允许其他用户修改该条数据,在这种情况下修改,就会出现:“记录被另外一个用户锁定”错误。

解决

查询用户、数据库锁、以及类型等

? 1 select object_id,session_id,locked_mode from v$locked_object;

或者

? 1 2 3 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掉会话进程

? 1 2 3 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掉该会话进程

? 1 alter system kill session 'sid,serial#'

本案例中kill进程语句为:

? 1 alter system kill session '1026,14490'

到这里,就可以解决“记录被另外一个用户锁定”错误,如果出现如下图错误:

说明你的权限不足,请用管理员账号登入数据库再重新1,2,3步骤,或者联系数据库管理员赋予你相关权限。

总结

到此这篇关于oracle报错记录被另外一个用户锁定的解决方案的文章就介绍到这了,更多相关oracle报错用户锁定内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/ForeverS2C/archive/2020/10/13/13811585.html

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章