我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle中有哪些锁处理方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle中有哪些锁处理方式

本篇文章为大家展示了Oracle中有哪些锁处理方式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1、查询锁情况

select sid,serial#,event,BLOCKING_SESSION from v$session where event like '%TX%';

2、根据SID查询具体信息(可忽略)

select sid,serial#,username,machine,blocking_session from v$session where sid=<SID>;

3、杀掉会话

#根据1和2中查到的SID和SERIAL# 定位会话,并杀掉

ALTER SYSTEM DISCONNECT SESSION '<SID>,<SERIAL>' IMMEDIATE;

ALTER SYSTEM KILL SESSION '<SID>,<SERIAL>';

 附件:

#查询阻塞脚本

col waiting_session for a20
col lock_type for a15
col mode_requested for a10
col mode_held for a10
col lock_id1 for a10
col lock_id2 for a10
set linesize 120
set pagesize 999
with dba_locks_cust as 
(SELECT  inst_id||'_'||sid session_id,
      DECODE (TYPE,
          'MR', 'Media Recovery',
          'RT', 'Redo Thread',
          'UN', 'User Name',
          'TX', 'Transaction',
          'TM', 'DML',
          'UL', 'PL/SQL User Lock',
          'DX', 'Distributed Xaction',
          'CF', 'Control File',
          'IS', 'Instance State',
          'FS', 'File Set',
          'IR', 'Instance Recovery',
          'ST', 'Disk Space Transaction',
          'TS', 'Temp Segment',
          'IV', 'Library Cache Invalidation',
          'LS', 'Log Start or Switch',
          'RW', 'Row Wait',
          'SQ', 'Sequence Number',
          'TE', 'Extend Table',
          'TT', 'Temp Table',
          TYPE)
        lock_type,
      DECODE (lmode,
          0, 'None',            
          1, 'Null',                     
          2, 'Row-S (SS)',                  
          3, 'Row-X (SX)',                  
          4, 'Share',                    
          5, 'S/Row-X (SSX)',                
          6, 'Exclusive',                  
          TO_CHAR (lmode))
        mode_held,
      DECODE (request,
          0, 'None',            
          1, 'Null',                     
          2, 'Row-S (SS)',                  
          3, 'Row-X (SX)',                  
          4, 'Share',                    
          5, 'S/Row-X (SSX)',                
          6, 'Exclusive',                  
          TO_CHAR (request))
        mode_requested,
      TO_CHAR (id1) lock_id1,
      TO_CHAR (id2) lock_id2,
      ctime last_convert,
      DECODE (block,
          0, 'Not Blocking', 
          1, 'Blocking',   
          2, 'Global',  
          TO_CHAR (block))
        blocking_others
   FROM gv$lock
),
lock_temp as
(select * from dba_locks_cust),
lock_holder as 
(
 select w.session_id waiting_session,
    h.session_id holding_session,
    w.lock_type,
    h.mode_held,
    w.mode_requested,
    w.lock_id1,
    w.lock_id2
 from lock_temp w, lock_temp h
 where h.blocking_others in ('Blocking','Global')
 and h.mode_held   != 'None'
 and h.mode_held   != 'Null'
 and w.mode_requested != 'None'
 and w.lock_type    = h.lock_type
 and w.lock_id1    = h.lock_id1
 and w.lock_id2    = h.lock_id2
),
lock_holders as
(select waiting_session,holding_session,lock_type,mode_held,
mode_requested,lock_id1,lock_id2
 from lock_holder
 union all
 select holding_session, null, 'None', null, null, null, null 
  from lock_holder
 minus
 select waiting_session, null, 'None', null, null, null, null
  from lock_holder 
 )
select lpad(' ',3*(level-1)) || waiting_session waiting_session,
    lock_type,
    mode_requested,
    mode_held,
    lock_id1,
    lock_id2
 from lock_holders
connect by prior waiting_session = holding_session
 start with holding_session is null;

上述内容就是Oracle中有哪些锁处理方式,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle中有哪些锁处理方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Golang中的错误处理方式有哪些

这篇文章主要讲解了“Golang中的错误处理方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Golang中的错误处理方式有哪些”吧!错误类型在Golang中,错误类型是错误处理的基本
2023-07-06

redis加锁的方式有哪些

这篇文章主要讲解了“redis加锁的方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“redis加锁的方式有哪些”吧!redis常见的加锁命令分别是INCR、SETNX、SET1、IN
2023-07-05

java加锁的方式有哪些

在Java中,有以下几种加锁的方式:1. synchronized关键字:使用synchronized关键字来修饰方法或代码块,实现对代码块的同步访问。当某个线程进入synchronized修饰的方法或代码块时,会自动获取锁,其他线程需要等
2023-08-16

java并发处理方式有哪些

Java 并发处理方式有以下几种:多线程:使用 Thread 类或实现 Runnable 接口创建多个线程,通过线程调度实现并发执行。线程池:使用 Executor 框架创建线程池,将任务提交给线程池进行执行,可以重复利用线程,提高性能。
2023-10-25

android事件处理方式有哪些

Android事件处理方式有以下几种:1. 匿名内部类:通过实现回调接口或重写事件监听器的方法来处理事件。2. 内部类:将事件处理逻辑封装在专门的内部类中,然后在外部类中调用内部类的方法来处理事件。3. 外部类:将事件处理逻辑封装在独立的外
2023-08-18

数据库死锁处理的方法有哪些

以下是一些处理数据库死锁的方法:1. 避免死锁:尽量设计良好的数据库结构,避免出现死锁的情况。可以使用合适的事务隔离级别,以及良好的并发控制策略。2. 死锁检测和回滚:当检测到死锁时,可以使用死锁检测算法来确定死锁的存在,并回滚其中一个或多
2023-09-20

java实现锁的方式有哪些

Java实现锁的方式有以下几种:synchronized关键字:使用synchronized关键字可以在方法或者代码块上加锁,确保在同一时间只有一个线程可以访问被锁定的代码。ReentrantLock类:ReentrantLock是Java
2023-10-24

oracle事务处理的方法有哪些

Oracle数据库提供了以下几种事务处理方法:使用 COMMIT 和 ROLLBACK 语句:使用 COMMIT 语句来提交事务,将事务中的所有更改永久保存到数据库中。使用 ROLLBACK 语句来回滚事务,将事务中的所有更改撤销并恢复到事
oracle事务处理的方法有哪些
2024-04-09

Java异常的处理方式有哪些

这篇文章主要介绍“Java异常的处理方式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java异常的处理方式有哪些”文章能帮助大家解决问题。什么是异常?异常在我们写代码是特别常见,因为程序员大
2023-06-30

C#处理异常的方式有哪些

本篇内容主要讲解“C#处理异常的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#处理异常的方式有哪些”吧!关于异常,从我们一开始写代码的时候就开始伴随着我们,只不过那时还没入门,脑子
2023-06-22

java并发处理的方式有哪些

Java并发处理的方式有以下几种:1. 使用synchronized关键字:通过在方法或代码块前加上synchronized关键字,确保同一时间只有一个线程可以执行该方法或代码块。这种方式是最常见的并发处理方式。2. 使用Lock接口及其实
2023-10-20

js中Array构造器的处理方式有哪些

小编给大家分享一下js中Array构造器的处理方式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、newArray(arg1,arg2,…),当参数长度为
2023-06-25

编程热搜

目录