ITPub博客

首页 > 数据库 > Oracle > UNDO表空间空间回收及切换

UNDO表空间空间回收及切换

原创 Oracle 作者:leon830216 时间:2018-03-10 18:25:47 0 删除 编辑
1. 查看 undo 相关参数
show parameter undo
NAME               TYPE     VALUE
------------------ -------- ----------
undo_management    string   AUTO
undo_retention     integer  900
undo_tablespace    string   UNDOTBS

2. 查看当前 undo 表空间的数据文件
select file_name,bytes from dba_data_files where tablespace_name = 'UNDOTBS1';

3. 每个 undo 段最多包含的事务数 (10g 已经废弃)
10g 默认一个 undo 段最多一个事务, undo 段不够时, 自动创建 undo 段
当 undo 表空间不够时, undo 段可以包含 1 个以上的事务 (undo段头可能会出现等待)
show parameter rollback
NAME                                 TYPE            VALUE
------------------------------------ --------------- -------
transactions_per_rollback_segment    integer         5

4. 查看 undo 回滚段状态
select * from dba_rollback_segs;
select a.usn, b.name, a.status, a.xacts, a.rssize/1024/1024/1024, a.hwmsize/1024/1024/1024, a.shrinks from v$rollstat a, v$rollname b where a.usn = b.usn order by a.rssize;

5. 创建新回滚表空间
create undo tablespace undo datafile '/usr/lib/oracle/xe/oradata/XE/undo.dbf' size 10m;

6. 切换 undo 表空间
alter system set undo_tablespace = undotbs scope = both;

7. 确认回滚段状态
反复确认 undo 回滚段状态, 直到全部回滚段为 online 状态, 没有pending_offline 状态, 最好到达 undo_retention 所限定的时间之后再删除
select a.usn, b.name, a.status, a.xacts, a.rssize/1024/1024/1024, a.hwmsize/1024/1024/1024, a.shrinks from v$rollstat a, v$rollname b where a.usn = b.usn order by a.rssize;

8. 删除原回滚表空间
drop tablespace undotbs including contents and datafiles;

EOF

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22558114/viewspace-2151703/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论

注册时间:2009-09-18

  • 博文量
    164
  • 访问量
    323075