分享

Oracle报错>记录被另外一个用户锁定

 python_lover 2022-02-27

原因

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

解决

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

    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)

  2. 查询对应的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;
    

    结果如:

  3. kill掉该会话进程

    alter system kill session 'sid,serial#'
    

    本案例中kill进程语句为:

    alter system kill session '1026,14490'
    

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

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

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多