oracle 异常session,Oracle中诊断阻塞session的方法 blocking error

由于锁的机制,当某一条DML或者DDL SQL语句执行被阻塞的时候,需要找出是什么原因导致这条SQL被阻塞了,下面介绍一下通常的诊断方法:

假设有这样一个表: table t(id int primary key,val int);数据为:

id  val

1   1

2    2

1,在一个Session,这里把它叫做Session A,做了如下的update语句,没有提交或者回滚.

SQL> update t set val = 3 where id=1;

2,在一另一个Session,这里把它叫做Session B,做了如下的update语句,Session B会被阻塞.

SQL> update t set val = 4 where id=1;

但有活动事务对对象加锁的时候,会在v$locked_object视图中有记录如object_id,session_id等,通常被阻塞的session的XIDUSN,XIDSLOT,XIDSQN字段都为空.下图中session_id为139的是被阻塞的session.

select * from v$locked_object;

06a4ba775f052ed546a464df0c00cc70.png

select dbo.* from  v$locked_object lo ,dba_objects dbo  where lo.object_id = dbo.object_id and lo.xidusn=0

9ce009b0a8461d652a8d1d8e255b9ad4.png

通过查询v$lock可以看到是哪一个session阻塞了哪一个session:142阻塞了139

with blkedsess as (select * from v$lock where request !=0)

select  blkingsess.sid blockingsid, blkedsess.sid blockedsid

from v$lock blkingsess,blkedsess

where blkingsess.id1 = blkedsess.id1

and blkingsess.id2 = blkedsess.id2

and blkingsess.sid != blkedsess.sid

53ff31f5654818afe0d672417f481679.png

在通过v$session可以查到session相关的信息,被阻塞的status一般为ACTIVE,还可以通过sql_address联合v$sql找到被阻塞的SQL语句.

select sid,serial#,status,sql_address from v$session where sid in(139,142)

7f5cb7d3cb66f5ce1b8849e710586098.png

select * from V$sql where address='6BE7D33C'

or

select sql_text, sql_fulltext, sql_id from v$sqlarea where sql_id='6BE7D33C';

or

select sql_text from v$sqltext where sql_id = '6BE7D33C';

3d5ab6b837cbae2f5c01ad8f14b63608.png

这时候DBA可以联系造成阻塞的session结束事务或者根据情况用命令终止session

alter system kill session '142,7'; 其中142为sid,7为serial#

session 142会收到如下错误,而session139往下执行后续步骤.

ERROR:

ORA-03114: not connected to Oracle0b1331709591d260c1c78e86d0c51c18.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值