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中多表级联删除的方法

    创建数据库时为了防止其他人不小心删除操作错误, 所有的外键都没有加级联删除。哪知,不知什么时候自己入了一批错误的数据进去,入库使用的是软件自动的,一下点错给自己带来无尽麻烦啊,删除就不好办了
    2013-07-07
  • Oracle关联表更新操作指南

    Oracle关联表更新操作指南

    这篇文章主要给大家介绍了关于Oracle关联表更新操作的相关资料, Oracle关联更新是一种用于更新多表中某个表的数据时,引用另一个表中的数据,以避免数据错误的技术,需要的朋友可以参考下
    2023-07-07
  • 深入oracle特定信息排序的分析

    深入oracle特定信息排序的分析

    本篇文章是对oracle特定信息排序进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 使用Navicat Premium工具将oracle数据库迁移到MySQL

    使用Navicat Premium工具将oracle数据库迁移到MySQL

    最近的业务项目需求,因此总结遇到的问题。使用Navicat Premium工具将Oralce数据库迁移到MySQL,本文通过图文的形式给大家详细介绍,感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • Oracle数据库下载及安装图文操作步骤

    Oracle数据库下载及安装图文操作步骤

    本文将介绍Oracle数据库下载及安装等一系列步骤,需要了解的朋友可以参考下
    2012-12-12
  • Oracle停止数据泵导入数据的方法详解

    Oracle停止数据泵导入数据的方法详解

    Oracle数据库在使用的过程中常常会遇到这样或那样的问题,而这些问题常常又使我们感到很困惑,下面这篇文章主要给大家介绍了关于Oracle停止数据泵导入数据的相关资料,需要的朋友可以参考下
    2022-06-06
  • Oracle 多参数查询语句

    Oracle 多参数查询语句

    这篇文章主要介绍了Oracle 多参数查询语句 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12
  • oracle查看被锁的表和被锁的进程以及杀掉这个进程

    oracle查看被锁的表和被锁的进程以及杀掉这个进程

    本节主要介绍了oracle如何查看被锁的表和被锁的进程以及杀掉这个进程,需要的朋友可以参考下
    2014-08-08
  • oracle分区表之hash分区表的使用及扩展

    oracle分区表之hash分区表的使用及扩展

    Hash分区是Oracle实现表分区的三种基本分区方式之一。对于那些无法有效划分分区范围的大表,或者出于某些特殊考虑的设计,需要使用Hash分区,下面介绍使用方法
    2014-01-01
  • oracle使用索引与不使用索引的性能详析

    oracle使用索引与不使用索引的性能详析

    索引是建立在表的一列或多个列上的辅助对象,目的是加快訪问表中的数据,下面这篇文章主要给大家分析介绍了关于oracle使用索引与不使用索引的性能的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-10-10

最新评论