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

发布时间:2022-04-20 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了Oracle报错记录被另外一个用户锁定的解决方案脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

原因

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

解决

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

@H_406_12@
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报错记录被另外一个用户锁定的解决方案全部内容,希望文章能够帮你解决Oracle报错记录被另外一个用户锁定的解决方案所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: