度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1506|回复: 7
打印 上一主题 下一主题

[分享] Oracle UNDO表空间

[复制链接]

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
跳转到指定楼层
楼主
发表于 2020-6-19 15:53:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
一、还原数据与还原表空间
还原数据是:
• 原始的、修改之前的数据副本
• 针对更改数据的每个事务处理而捕获
• 至少保留到事务处理结束
• 用于支持:
– 回退操作
– 读取一致性查询
– Oracle 闪回查询、Oracle 闪回事务处理和 Oracle 闪回表
– 从失败的事务处理中进行恢复
还原信息存储在还原段中,还原段又存储在还原表空间中。
还原表空间:
• 仅用于还原段
• 有特殊的恢复注意事项
• 只能与单个实例相关联(集群情况还原表空间是分开的)
• 在任意给定时间,一个给定的实例只能有一个表空间是当前可写还原表空间

二、事务处理与还原数据
• 每个事务处理仅分配一个还原段。
• 一个还原段可以同时服务多个事务处理。

三、还原数据与重做数据

四、相关参数说明
以上为默认值。
启用自动还原管理:UNDO_MANAGEMENT='AUTO'
设置还原保留时间:UNDO_RETENTION=10800 --这个参数一般设置3小时,设置大点200G左右
设置还原表空间:UNDO_TABLESPACE='UNDOTBS1'

五、设置 还原保留时间
脚本修改立即生效无需重启:
alter system set undo_retention=10800
UNDO_RETENTION 指定已提交的还原信息要保留多长时间(秒),默认为900秒。
仅在以下情况下才必须设置此参数:
• 还原表空间启用了 AUTOEXTEND 选项
• 需要设置 LOB 的还原保留时间
• 需要保证保留时间
还原保留时间是建议值,当UNDO表空间满了且没到900秒也会覆盖,如果需要确保必须保留900秒,则需要设置保证还原保留时间

六、设置 保证还原保留时间
SQL> ALTER TABLESPACE undotbs1 RETENTION GUARANTEE;--保证还原保留时间
SQL> ALTER TABLESPACE undotbs1 RETENTION NOGUARANTEE;--不保证还原保留时间
在有guarantee的保证下,ORACLE将会保证undo信息能够保存到undo_retention设定的值之后才被覆盖,如果这个时候同时执行了很多事物,将undo表空间耗完了,那么那个事物会失败,会报ORA-30036 错误,所以使用guarantee一定要慎用,如果非要使用guarantee,那么尽量将undo 表空间设大一点。
七、还原数据的使用
1、闪回查询
说明:查询指定时间点的所有数据
select empno, ename, job, mgr, sal
from scott.emp
as of timestamp to_timestamp('2016-01-21 15:10:00', 'yyyy-mm-dd hh24:mi:ss')
where mgr = 7566;

2、闪回版本查询
说明:
(1)查看两个时间点之间行的所有版本。
(2)查看更改了行的事务处理。
注意:
(1)不能使用 VERSIONS 子句查询外部表、临时表、固定表、视图。
(2)VERSIONS 子句不能跨 DDL 命令使用。
(3)段收缩操作已过滤掉。
SELECT DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER FROM DUAL;--获取SCN
update…commit;inset…commit;delete…commit;
SELECT DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER FROM DUAL;--获取SCN
select VERSIONS_STARTSCN,versions_starttime,VERSIONS_ENDSCN,versions_endtime,versions_xid,versions_operation
from employees versions between scn 2797818 and 2797868
order by VERSIONS_STARTTIME;
select VERSIONS_STARTSCN,versions_starttime,VERSIONS_ENDSCN,versions_endtime,versions_xid,versions_operation
from employees versions between timestamp minvalue and maxvalue
order by VERSIONS_STARTTIME;

   3、闪回表
说明:
(1)需要具有对特定表的 FLASHBACK ANY TABLE 或 FLASHBACK 对象权限和具有 SELECT、INSERT、DELETE 和 ALTER 权限。
(2)FLASHBACK TABLE 命令作为单个事务处理执行,要求获取 DML 排它锁。
(3)不闪回统计信息,保留当前索引和从属对象。
(4)操作不能对系统表执行,不能跨DDL操作,会生成还原数据和重做数据。


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
沙发
 楼主| 发表于 2020-6-20 15:42:53 | 只看该作者
回复

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
板凳
发表于 2020-6-20 17:39:11 | 只看该作者
强势围观
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
地板
 楼主| 发表于 2020-6-21 14:10:32 | 只看该作者
回复 支持 反对

使用道具 举报

542

主题

5916

帖子

1万

积分

作者

Rank: 7Rank: 7Rank: 7

积分
13589
5#
发表于 2020-6-21 14:13:39 | 只看该作者
回复 支持 反对

使用道具 举报

141

主题

1551

帖子

3573

积分

论坛元老

Rank: 8Rank: 8

积分
3573
6#
发表于 2020-6-24 18:03:54 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
7#
 楼主| 发表于 2020-6-25 14:36:09 | 只看该作者
回复 支持 反对

使用道具 举报

235

主题

2547

帖子

5835

积分

论坛元老

Rank: 8Rank: 8

积分
5835
8#
 楼主| 发表于 2020-6-25 14:37:10 | 只看该作者
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-24 11:02 , Processed in 0.135231 second(s), 25 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表