Oracle undo表空间

Oracle的Undo表空间用于保存事务回滚信息,确保读一致性与数据库恢复。回退段按循环写入方式工作,事务开始时分配一个回退段。管理包括创建、修改、删除和切换Undo表空间,以及调整回退信息保留时间。通过启用retention guarantee,可保证长时间读一致性和闪回操作。
摘要由CSDN通过智能技术生成

Oracle undo表空间详解

回退段介绍

在Oracle数据库中,当某个事物对数据进行修改时,Oracle首先将数据的原始值保存到一个回退段中。一个事物只能将它的回退信息保存到一个回退段中,而多个并行事物可以使用同一个回退段。

1、回退段的作用

回退段主要有4个作用,分别是:事物回滚、数据库恢复、读一致性、闪回查询。

  --事物回滚:当事物执行失败或用户执行回滚操作(rollback)时,Oracle会利用保存在回退段中的信息将数据恢复到原来的值;

  --数据库恢复:当数据库实例运行失败,在数据库重启恢复时,Oracle先利用重做日志文件的信息对数据库进行恢复(包括已提交和未提交的事务),再利用回滚段中的信息回滚未提交的事务;

  --读一致性:当一个用户对数据进行修改时,会预先将其原始值保存到回退段中,这时,如果有其它用户访问该数据,则访问回退段中的信息,使当前用户未提交的修改其他用户无法看到,保证了数据的一致性;

  --闪回查询:通过保留在回退段中的信息,用户可以查询某个数据在过去某个时刻的状态

2、回退段的工作方式

当事务开始时,系统分配给该事物一个回退段,在事务的整个生命周期中,当数据发生改变时,数据的原始值被复制到回退段中。回退段采用循环写的方式进行工作,当事务写满回退段的一个区之后,会接着写入回退段的下一个区,当所有的区都写满后,事务开始循环写入到第一个区或者分配新的区(datafile为autoextend)。回退段归用户sys所有,每个回退段至少包含2个区。

回退表空间的管理

1、创建undo表空间

在Oracle 11g中,创建undo tablespace有2种方法,一种是在创建数据库时创建undo tablespace,另一种是使用create undo tablespace来创建undo tablespace。undo tablespace用来保存事务的回退信息,用户不能在其中创建数据库对象。

我们这里介绍如何使用craete undo tablespace 来创建undo表空间。

复制代码
--使用create undo tablespace
CREATE [BIGFILE | SMALLFILE] UNDO TABLESPACE tbs_name
DATAFILE 'path/filename' SIZE integer [K | M] [
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值