Oracle锁表问题的解决方法

 更新时间:2024年04月25日 11:04:33   作者:小海海不怕困难  
在实际工作中,并发量比较大的项目,经常会出现锁表的问题,下面我将复现这个问题,并给出解决方法,文中通过代码示例和图文介绍的非常详细,需要的朋友可以参考下

一、问题复现

1、session1修改aabb表的B字段为迪迦奥特曼,但是不提交该事务

2、session2也修改这行的这个字段

发现该字段的执行时间一直停滞,无法执行。两个session会相互争抢 ,一直无法执行,进而导致系统卡顿崩溃

二、解决方法

1、查询竞争资源的表或语句

运行一下语句查询锁表的语句。

-- 查询未提交事务的session信息,注意执行以下SQL,用户需要有DBA权限才行
SELECT
    L.SESSION_ID,
    S.SERIAL#,
    L.LOCKED_MODE AS 锁模式,
    L.ORACLE_USERNAME AS 所有者,
    L.OS_USER_NAME AS 登录系统用户名,
    S.MACHINE AS 系统名,
    S.TERMINAL AS 终端用户名,
    O.OBJECT_NAME AS 被锁表对象名,
    S.LOGON_TIME AS 登录数据库时间
FROM V$LOCKED_OBJECT L
    INNER JOIN ALL_OBJECTS O ON O.OBJECT_ID = L.OBJECT_ID
    INNER JOIN V$SESSION S ON S.SID = L.SESSION_ID
WHERE 1 = 1

查询结果如下 

2、强制释放资源 

运行一下语句可以杀死对应的锁表进程

通用语句:强制 结束/kill 锁表会话语法
ALTER SYSTEM KILL SESSION 'SESSION_ID, SERIAL#';
 
示例语句:强制杀死session1,让session2可以修改a = '3228730285638861'的那条记录
ALTER SYSTEM KILL SESSION '4984, 28973';

杀死session1的进程后,session2顺利执行。

以上就是Oracle锁表问题的解决方法的详细内容,更多关于Oracle锁表的资料请关注脚本之家其它相关文章!

相关文章

  • oracle数据库查询表被锁多种方式实现

    oracle数据库查询表被锁多种方式实现

    本文介绍了在Oracle数据库中如何通过V$LOCKED_OBJECT、DBA_OBJECTS和DBA_LOCKS、VSESSION和VLOCK、DBA_BLOCKERS和DBA_WAITERS、V$LOCK等视图查询表是否被锁定的方法,这些视图提供了详细的锁信息,包括锁的类型、模式以及持有锁的会话信息,需要的朋友可以参考下
    2024-10-10
  • 查看oracle数据库的编码及修改编码格式的方法

    查看oracle数据库的编码及修改编码格式的方法

    本节主要介绍了如何查看oracle数据库的编码及修改编码格式,需要的朋友可以参考下
    2014-07-07
  • Oracle中锁(lock)的用法

    Oracle中锁(lock)的用法

    这篇文章介绍了Oracle中锁(lock)的用法 ,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-05-05
  • Oracle中decode函数应用示例详解

    Oracle中decode函数应用示例详解

    Oracle DECODE函数功能很强,这篇文章主要给大家介绍了关于Oracle中decode函数应用示例的相关资料,文中通过代码介绍的非常详细,对大家学习或者使用oracle具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-05-05
  • oracle数据库导入导出命令解析

    oracle数据库导入导出命令解析

    这篇文章主要介绍了oracle数据库导入导出命令解析,小编觉得还是比较不错的,需要的朋友可以参考下。
    2017-10-10
  • oracle11g密码复杂性校验开启关闭方式

    oracle11g密码复杂性校验开启关闭方式

    这篇文章主要介绍了oracle11g密码复杂性校验开启关闭方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Oracle如何查看impdp正在执行的内容

    Oracle如何查看impdp正在执行的内容

    这篇文章主要给大家介绍了关于Oracle如何查看impdp正在执行的内容的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Oracle具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • Oracle 11g数据库安装与卸载的方法图解

    Oracle 11g数据库安装与卸载的方法图解

    如果小编使用的是win7系统,最好采用11g,否则很可能10g出现不兼容安装不成功的情况。下面给大家分享Oracle 11g数据库安装与卸载的方法图解,非常不错,感兴趣的朋友一起看看吧
    2016-09-09
  • Oracle存储过程基本语法介绍

    Oracle存储过程基本语法介绍

    Oracle存储过程基本语法介绍,有需求的朋友可以参考下
    2012-11-11
  • oracle数据库如何给用户授权查询权限

    oracle数据库如何给用户授权查询权限

    这篇文章主要给大家介绍了关于oracle数据库如何给用户授权查询权限的相关资料,授予权限是数据库管理中的重要任务,它可以确保用户有权访问所需的数据库对象,并执行必要的操作,需要的朋友可以参考下
    2024-01-01

最新评论