Oracle kill session

本文介绍了解决Oracle数据库中表锁问题的步骤。首先通过查询锁定表关联的会话信息来定位问题,然后使用ALTER SYSTEM KILL SESSION命令来释放锁定会话。文中还特别指出此方法不适用于临时表。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  第一步:查询被锁表的所关联的session信息

 

SELECT A.OWNER,
       A.OBJECT_NAME,
       B.XIDUSN,
       B.XIDSLOT,
       B.XIDSQN,
       B.SESSION_ID,
       B.ORACLE_USERNAME,
       B.OS_USER_NAME,
       B.PROCESS,
       B.LOCKED_MODE,
       C.MACHINE,
       C.STATUS,
       C.SERVER,
       C.SID,
       C.SERIAL#,
       C.PROGRAM
  FROM ALL_OBJECTS A, V$LOCKED_OBJECT B, SYS.GV_$SESSION C
 WHERE (A.OBJECT_ID = B.OBJECT_ID)
   AND (B.PROCESS = C.PROCESS)

 

    第二步:释放Session

  

alter system kill session 'sid, serial#'

alter system kill session '379, 21132'
alter system kill session '374, 6938'

 

   不过这种情况只适合实体表,如果临时表被锁住,好像在V$Locked_OBJECT表中查不到记录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值