Oracle: 行锁等待时从V$active_session_history中的信息构建rowid

行锁等待时从V$active_session_history中的信息构建rowid

行锁等待(enq: TX - row lock contention)出现时,有时想要得到具体是等待在哪一行数据上,V$active_session_history中有几个字段可用于构建rowid:current_obj#,current_file#,current_block#,current_row#。

其中需要注意的是current_obj#对应的是dba_objects.object_id,但是dbms_rowid.rowid_create构建rowid时,实际使用的是dba_objects.data_object_id。

所以当dba_objects.object_id<>dba_objects.data_object_id时,使用object_id构建的rowid会不准确或报无效rowid错误。

--dbms_rowid.rowid_create:
FUNCTION ROWID_CREATE RETURNS ROWID
 Argument Name                  Type                    In/Out Default?
 ------------------------------ ----------------------- ------ --------
 ROWID_TYPE                     NUMBER                  IN         << 1 - extended , 0 - restricted
 OBJECT_NUMBER                  NUMBER                  IN         << data_object_id
 RELATIVE_FNO                   NUMBER                  IN
 BLOCK_NUMBER                   NUMBER                  IN
 ROW_NUMBER                     NUMBER                  IN

查询V$active_session_history中行锁等待事件相关会话信息,同时获取相关数据行的rowid:

select to_char(sample_time, 'YYYYMMDD-hh24miss') as stime,
       session_id,
       session_serial# as ss,
       SQL_EXEC_START,
       session_state,
       event,
       p1,
       p2,
       P3,
       wait_time,
       time_waited,
       blocking_session as block_sid,
       sql_id,
       program,
       machine,
       dbms_rowid.rowid_create('1',
                               (select data_object_id
                                  from dba_objects
                                 where object_id = a.current_obj#),
                               current_file#,
                               current_block#,
                               current_row#) row_id
  from V$active_session_history a
 where sample_time between
       to_date('2021-03-12 11:07:01', 'YYYY-MM-DD hh24:mi:ss') and
       to_date('2021-03-12 11:08:01', 'YYYY-MM-DD hh24:mi:ss')
   and event = 'enq: TX - row lock contention'
 order by sample_time;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值