1、redo
redo即是重做日志文件,分为在线(online)重做日志文件和归档(archived)重做日志文件,这两类重做日志文件都用于恢复;当用户在Buffer Cache 中修改数据时,Oracle 并不会立即将修改数据写出到数据文件上,假设出现断电或磁盘异常的情况下,可以通过在线重做日志文件和归档重做日志文件将未更新到磁盘的数据进行重做。默认的,数据库创建时会建立3个日志组。当所有组都写满之后,日志进程再次开始写第一个,后面的数据覆盖前面的数据,即为非归档模式。 鉴于redo如此重要,需要将已写满的日志归档,即复制redo内容到其他地方,即开启归档日志模式,一般情况下,测试环境可以关闭归档日志,生产必须开启归档日志保证数据安全。
2、undo
undo的事务回滚:redo是重做我们的操作,undo则相反,当我们对数据进行修改时,数据库会生成undo信息,也就是说被修改的元数据存到undo中,这样万一你执行的事务或语句由于某种原因失败了,或者如果你用一条ROLLBACK语句请求回滚,就可以利用这些undo信息将数据放回到修改前的样子,但回滚是在逻辑层面实现而不是物理层面,因为在一个多用户系统中,数据结构,blocks等都在时时变化,比如我们 INSERT一个数据,表的空间不够,扩展了一个新的EXTENT,我们的数据保存在这新的EXTENT里,其它用户随后也在这EXTENT里插入了数据,而此时我想ROLLBACK,那么显然物理上讲这EXTENT撤销是不可能的,因为这么做会影响其他用户的操作。所以,ROLLBACK是逻辑上回滚
undo的读一致性:用户检索数据时,ORACLE总是使用户只能看到被提交过的数据,这是由Oracle自动提供的。当用户修改数据,但是没有提交时,另外一个用户使用select语句查找该值时,该值就是从undo表空间中取得的。
undo的事务恢复:事务恢复是例程恢复的一部分,它是由Oracle Server自动完成的。如果在数据库运行过程中出线例程失败,那么当启动Oracle Server时,后台进程SMON会自动执行例程恢复。执行例程恢复时,Oracle会重做所有未应用的记录。然后打开数据库,回退未提交事务。
undo的闪回查询:根据undo信息,利用undo数据,取得某一特定时间点的数据库数据。
浙公网安备 33010602011771号