thinkpadshi 2015-12-21 02:08 采纳率: 50%
浏览 1738
已结题

oracle中scn号是commit之后产生的,还是commit之前产生的?

如果是commit之后产生的,那么在commit之前scn都没有,还怎么用比较scn号大小的方法来实现读一致性呢?
假设scn号是在commit之后产生的,在判断读一致性时是根据scn号的大小去控制的,比如事务开始时最大的scn号是1000,当读到此事务开始之后有人修改过但未提交的数据时,比如这次修改的scn是1001,系统一看比事务开始时最大的scn号1000还大,就直接去undo中读取被修改之前的数据来保持读一致性,但是这是基于scn号是在修改数据之后,commit之前产生的,那就跟scn号是commit之后产生的矛盾了

  • 写回答

2条回答 默认 最新

  • beyon2008 2015-12-22 06:51
    关注

    commit之前就产生了

    评论

报告相同问题?