Oracle事务开始时的SCN

Oracle为每一个事物都分配一个唯一的SCN值,事务开始时的SCN可以从V$TRANSACTION.START_SCNB+ START_SCNW中查询,如下所示:
SQL> update t2 set obj#=1 where rownum=1;

1 row updated.

SQL> select XIDUSN,START_SCNB,START_SCNW from vtransaction2whereSESADDR=(selectSADDRfromvtransaction 2 where SES_ADDR=(select SADDR from vtransaction2whereSESADDR=(selectSADDRfromvsession
3 where sid=(select sid from v$mystat where rownum=1)
4 );

也可以通过DUMP回滚段头来观察事务开始时的SCN,如下所示:
SQL> select name from v$rollname where usn=10;

SQL> ALTER SYSTEM DUMP UNDO HEADER ‘_SYSSMU10$’;

System altered.
打开跟踪文件(以下显示有部分省略),state为10表示这是一个未提交的事务,scn表示事务开始SCN。如下所示:

0x1c 10 0x80 0x012a 0x0002 0x0000.000b97d1 0x0080bac3 0x0000.000.00000000 0x00000001 0x00000000 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值