Oracle undo回滚段详解(2)

  Redo 是为了重新实现你的操作,而Undo相反,是为了撤销你做的操作。Undo更像常使用的ctrl+z ,撤销到上一步的状态。而Redo 是也就会记录undo 的操作。

Oracle undo回滚段详解

当我们插入一条数据时,首先这个动作会被记录到redo log 中,操作也会被记录到到undo ,undo本身的动作也会做为一条数据被记录到redo log ,插入一条数据,索引(indexes)会发生变化,索引的变化也会做一条数据被记录到redo log 。Redo 记录着一个操作所有相关的信息,这样才能完整的保证场景的重现。
 

  需要说明的是在上面的图表中,不管是undo 还是redo都是写在内存里的,一旦断电,所有信息将会消失。是redo log 的信息先写到磁盘上的,在实例进行恢复的时候首先进行前滚(redo),将undo的内容也会前滚回去,然后再根据undo里的内容进行回滚(undo)。

4. 如何配置使用undo?       

  要想使用undo 首先需要创建undo表空间。我们可以创建多个undo表空间,但只能有一个undo表空间是处于使用状态。

查看undo配置信息:

SQL> show parameter undo

NAME                          TYPE                VALUE

------------------------------------ ----------------------------------------------------

undo_management                string            AUTO 

undo_retention                  integer          900

undo_tablespace                  string          UNDOTBS1

Undo配置参数含义

-DNDO_MANAGEMENT    undo的管理模式,分自动和手动

-UNDO_TABLESPACE      当前正在被使用的undo表

-UNDO_RETENTION        规定多长时间内,数据不能被覆盖。

-----------------------------------------
 

AUTO            表示undo为自动管理模式。

900              表示在900秒内,undo上的数据不能被覆盖。

UNDOTBS1    是当前正在使用的undo表空间。

创建undo表空间,与创建一般的表空间类似,命令如下:

SQL> create undo tablespace myundotbs

2  datafile '/ora10/product/oradata/ora10/myundotbs1.dbf' size 10M;

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/b0f7e07721da354d1d7860053f045710.html