当前位置:  数据库>oracle

Oracle 在线段收缩(Online Segment Shrink)

    来源: 互联网  发布时间:2017-05-25

    本文导语: Oracle的在线段收缩(Online Segment Shrink)是指在线整理段空间里的碎片,它有以下几个特点:  在线,即在段压缩过程中,DML几乎不受影响(只有在结束前很短的时间内,DML会被阻塞) in-place的操作,不需要额外的空间 收缩完成...

Oracle的在线段收缩(Online Segment Shrink)是指在线整理段空间里的碎片,它有以下几个特点: 

  • 在线,即在段压缩过程中,DML几乎不受影响(只有在结束前很短的时间内,DML会被阻塞)
  • in-place的操作,不需要额外的空间
  • 收缩完成后索引依然可用
它不但能够收回高水位线以上未使用的空间,还可以收回高水位线下为使用的空间,它的主要步骤是:
  • 压缩段空间
  • 调整高水位线
  • 释放收回的空间
  • 使用Shrink有两个前提条件:
  • 表必须启用row movement
  • 表段所在表空间的段空间管理(segment space management)必须为auto
  • 在线段收缩的语法如下:

    alter table/index/materialized view object_name shrink space [cascade] [compact];

    • cascade:是指压缩所有依赖的对象,比如压缩表语句加上cascade,表上所有的索引都会被压缩
    • compact:把压缩过程分为两个阶段:第一个阶段的语句带compact,压缩段空间,在这个过程中需要在表上加RX锁,即只在需要移动的行上加锁。由于涉及到rowid的改变,需要enable row movement.同时要disable基于rowid的trigger.这一过程对业务影响比较小。;第二个阶段语句不带compact,调整高水位并释放收回的空间。此过程需要在表上加X锁,会造成表上的所有DML语句阻塞。在业务特别繁忙的系统上可能造成比较大的影响。对于大表,建议采用compact选项。
    下面我们以一个实际例子来说明:
    首先创建一个测试表和其上的一个索引:

    SYS@TEST16>create table t as select * from dba_objects;

    Table created.

    SYS@TEST16>create index i on t(object_id);

    Index created.

    查看表和索引的空间使用情况:

    SYS@TEST16>select segment_name,segment_type,bytes,blocks from dba_segments where owner='TEST' and segment_name in
      2  (select 'T' from dual UNION ALL  select index_name from dba_indexes where table_owner='TEST' and TABLE_NAME='T');

    SEGMENT_NAME                  SEGMENT_TYPE            BYTES    BLOCKS
    ------------------------------ ------------------ ---------- ----------
    T                              TABLE                9437184      1152
    I                              INDEX                2097152        256

    删除表数据,发现表和索引的空间并没有被收回:

    SYS@TEST16>delete from t;

    72568 rows deleted.

    SYS@TEST16>commit;

    Commit complete.

    SYS@TEST16>select segment_name,segment_type,bytes,blocks from dba_segments where owner='TEST' and segment_name in
      2  (select 'T' from dual UNION ALL  select index_name from dba_indexes where table_owner='TEST' and TABLE_NAME='T');

    SEGMENT_NAME                  SEGMENT_TYPE            BYTES    BLOCKS
    ------------------------------ ------------------ ---------- ----------
    T                              TABLE                9437184      1152
    I                              INDEX                2097152        256

    直到做了段收缩之后,空间才被真正收回:

    SYS@TEST16>alter table t enable row movement;

    Table altered.

    SYS@TEST16>alter table t shrink space cascade compact;

    Table altered.

    SYS@TEST16>alter table t shrink space cascade;

    Table altered.

    SYS@TEST16>select segment_name,segment_type,bytes,blocks from dba_segments where owner='TEST' and segment_name in
      2  (select 'T' from dual UNION ALL  select index_name from dba_indexes where table_owner='TEST' and TABLE_NAME='T');

    SEGMENT_NAME                  SEGMENT_TYPE            BYTES    BLOCKS
    ------------------------------ ------------------ ---------- ----------
    T                              TABLE                  65536          8
    I                              INDEX                  65536          8

    推荐阅读:

    Oracle基础教程之通过RMAN复制数据库

    RMAN备份策略制定参考内容

    RMAN备份学习笔记

    Oracle数据库备份加密 RMAN加密


        
     
     

    您可能感兴趣的文章:

     
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,