Oracle11g表空间10--撤销表空间

撤销表空间(用于存储事务的撤销数据,在数据恢复时使用)
a. 为了实现对数据回退,恢复,事物回滚以及撤销操作,Oracle数据库提供了一部分存储空间,专门保存撤销记录,将修改前的数据保存到该空间中,所以这部分表空间被称为撤销表空间。
b. 多个撤销表空间可以存在于一个数据库中,但是在任何给定的时间只有一个撤销表空间是可以获得的。
c. 默认情况下,数据库使用的是系统自动创建的undotbs1撤销表空间。

创建撤销表空间,使用用到关键字undo
create undo tablespace undbspace
datafile 'D:\app\SQLTest\Self\undotablespace01.dbf' size 20m
autoextend on;

删除撤销表空间(使用drop tablespace tablespace_name)
注意: 删除的前提是该撤销表空间此时没有被数据库使用。 如果需要删除正在被使用的撤销表空间,则应该先执行撤销表空间的切换操作。
 drop tablespace undo_tablespace including contents and datafiles;

切换撤销表空间
使用alter system语句修改undo_tablespace的值即可。切换撤销表空间后,数据库中新事物的撤销数据将保存在新的撤销表空间中。
如; alter system set undo_tablespace = undotbs02;


修改撤销表空间的数据文件。
a. 为撤销表空间添加一个新的数据文件
	alter tablespace undotablespace01 add datafile 'e:\dbspace.db' size 1m

b.修改撤销表空间中数据文件大小
	alter tablespace datafile 'e:\undotablespace.dbf' resize 15m;
c.设置撤销表空间的数据文件/表空间本身的状态online/offline.
	alter database datafile file_name online|offline|offline drop
	alter tablespace tablespace_name on|off


修改撤销记录保留的时间:
  a. 在自动撤销记录管理方式中,可以指定撤销信息在提交之后需要保留的时间,
以防止在长时间的查询过程中出现snapshot too old 错误。
在自动撤销管理方式下,dba使用undo_retention参数,指定撤销记录的保留时间。
  b. 由于undo_retention参数是一个动态参数,在Oracle实例的运行中,可以通过
   alter system set undo_retention 语句,来修改撤销记录保留的时间。
撤销记录保留时间的单位是秒,默认是900s.
例如:将撤销记录的保留时间修改为10分钟,如下:
alter system set undo_retention = 600;
SQL> show parameter undo;

NAME                                 TYPE        VALUE
------------------------------------ ----------- -----------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDOTBS1
SQL> alter system set undo_retention = 600;

系统已更改。

SQL> show parameter undo;

NAME                                 TYPE        VALUE
------------------------------------ ----------- -----------------------------
undo_management                      string      AUTO
undo_retention                       integer     600
undo_tablespace                      string      UNDOTBS1
SQL>



你可能感兴趣的:(切换撤销表空间,撤销表空间)