最简单说,你的数据暂时存放的地方,当你commit的时候释放
举例,你删除一个表的数据,然后发现错了,你可以rollbak取消,这过程,就是回滚

解决方案 »

  1.   

    leborety(那只螃蟹) 正解,^_^。
      

  2.   

    准确的说,回滚段里放的是被修改数据的前像,用来提高读/写操作的并发度回滚段里某个事务使用的空间不会被释放,在commit后会被其它事务重用
      

  3.   

    1.保存DML操作前数据
      比如表中有记录A,B,如果执行delete或update操作记录B,还没有执行commit,这时表中只剩下A或修改后的B,而操作前的数据信息会暂存在回滚段,如果你想恢复操作前的数据,执行rollback即可;
    2.数据读一致性
      如上,如果一个用户对表进行了操作删除了记录B,还没有提交,而此时另外一个用户对该表查询,查询结果将是A和B两条记录,B记录来源于回滚段,如果执行DML操作的用户执行了commit;所有用户再对该表进行查询看到的将是修改后的结果。