Oracle Undo 和 Redo

1. REDO(重做信息)

Redo log file(重做日志文件),是数据库的事务日志。

Oracle维护着两类重做日志文件:在线(online)重做日志文件和归档(archived)重做日志文件,这两类重做日志文件用于实例失败或是介质失败时数据的恢复;

如果数据库所在主机突然断电导致实例失败,则Oracle会使用在线重做日志将系统恰好恢复到掉电之前的时间点;

如果硬盘出现故障(即介质失败),Oracle会使用归档重做日志和在线重做日志将硬盘上的数据恢复到适当的时间点;

另外如果你无意地上除了某些重要信息并提交了这个操作,那么可以恢复受影响数据的一个备份,并使用在线和归档重做日志文件把它恢复到之前的一个时间点;

重做日志文件可能是数据库中最重要的恢复结构,但同时其他部分(如undo段、分布式事务恢复等)也不可或缺,重做日志是数据库区别于传统文件系统的一个重要特征;

2. UNDO(撤销信息)

当对数据执行DML(增、删、改)时,数据库会生成undo信息,万一你执行事务或语句由于某些原因失败时,或者你用一条语句rollback语句请求回滚时,数据库就可以利用这些undo信息将数据返回到修改前的样子。

3. REDO 和 UNDO 区别

① Redo用于在失败时恢复事务,undo用于取消一条语句或者一组语句的作用;

② Undo信息存储在数据库内部一组特殊段中(undo segment);

③ Undo并不是使数据库物理地回复到执行语句或者事务之前的样子,数据库只是逻辑地回复到原来的样子,所有的修改都被逻辑地取消,但是数据库结构以及数据库块在回滚后可能还与回滚前保持一致;

因为在多用户系统中,可能会有数百或者上千个并发事务,不仅仅你的事务在修改一些块,其他许多人的事务也可能在修改这些块,因此,不能简单地将一个块放到你事务开始前的样子,这样很可能会撤销其他人的事务工作。

例如:

假设你的事务执行了一个insert语句,这条语句导致分配了一个新的区段;

通过执行这个insert,你将会获得一个新的数据库块,并在格式化该块后在其中放入一些数据;

此时,可能出现另外的事务,它也往这个块中插入数据;如果你要回滚你的事务,显然蹦年取消对这个数据块已有的格式化和空间分配,否则会影响到另外的那个事务的工作。

因此回滚是,Oracle实际上会做与之前逻辑上相反的工作,即:

对于每个insert,会执行一个delete;

对于每个delete,会执行一个insert;

对于每一个update,会执行一个“反update”,或者执行另一个update将修改前的行放回去;

还有一点需要特别注意:undo对于直接路径操作(即使用append提示进行insert)不适用,直接操作能绕过表上的undo生成。

分区索引:https://www.cnblogs.com/Dreamer-1/p/6132776.html

原文地址:https://www.cnblogs.com/wangrui1587165/p/9505216.html