Oracle回滚段使用查询

来源:互联网 发布:淘宝联盟默认推广位 编辑:程序博客网 时间:2024/05/19 17:04

大批量执行DML语句造成回滚段大量占用,又回退操作,如何直观查询数据回滚情况?



单机环境 查询回滚执行进度
select /*+ rule */s.sid,
     r.name rr,
       nvl(s.username,'no transaction') us,
       s.osuser os,
       s.terminal te,
       t.used_urec rec,
       t.used_ublk blk
  from v$lock l, v$session s, v$rollname r,v$transaction t
 where l.sid = s.sid(+) and
       trunc(l.id1/65536) = r.usn and
       l.type = 'TX' and
       t.ses_addr = s.saddr and
       l.lmode = 6;


单机环境 查询回滚执行进度
select /*+ rule */s.sid,
     r.name rr,
       nvl(s.username,'no transaction') us,
       s.osuser os,
       s.terminal te,
       t.used_urec rec,
       t.used_ublk blk
  from v$lock l, v$session s, v$rollname r,v$transaction t
 where l.sid = s.sid(+) and
       trunc(l.id1/65536) = r.usn and
       l.type = 'TX' and
       t.ses_addr = s.saddr and
       l.lmode = 6;

集群环境  查询回滚执行进度
select /*+ rule */s.sid,
     r.name rr,
       nvl(s.username,'no transaction') us,
       s.osuser os,
       s.terminal te,
       t.used_urec rec,
       t.used_ublk blk
  from gv$lock l, gv$session s, v$rollname r,gv$transaction t
 where l.sid = s.sid(+) and
       trunc(l.id1/65536) = r.usn and
       l.type = 'TX' and
       t.ses_addr = s.saddr and
       l.lmode = 6;

单机环境 查询回滚执行进度
select /*+ rule */s.sid,
     r.name rr,
       nvl(s.username,'no transaction') us,
       s.osuser os,
       s.terminal te,
       t.used_urec rec,
       t.used_ublk blk
  from v$lock l, v$session s, v$rollname r,v$transaction t
 where l.sid = s.sid(+) and
       trunc(l.id1/65536) = r.usn and
       l.type = 'TX' and
       t.ses_addr = s.saddr and
       l.lmode = 6;
原创粉丝点击