dbms_redefinition在线重定义表结构

(2013-08-29 22:52:58)

刚接手一套系统应用数据库,因为项目建设期间种种原因,库是非归档模式也没有备份,更让我无语的是有个表增长的比较快,将近90G大小,每隔一段时间都要删除前三个月以前的数据,然后再用shrink收缩空间,因为是非分区表,shrink很是浪费时间,而且很多时间无法正常完成shrink操作,想将它改成分区表,同时业务部门又允许停数据库,只能利用ORACLE 10g的一个新特性,DBMS_REDEFINITION包在线转换成分区表,然后将以前的分区直接truncate掉,这样以前几个小时才能完成的工作,1分钟内就可以搞定,具体操作过程如下。

    操作环境说明:ORACLE 10G 10.2.0.4,HP-UNIX系统

    DBMS_REDEFINITION包支持在线对表结构进行重定义,包括添加、删除列等操作,整个操作过程中只在数据同步时对原表临时进行加锁处理,基本上可以忽略对业务的影响,特别是对于银行、电信行业非RAC环境使用DBMS_REDEFINITION对表行DDL修改是一种非常不错的选择。

    在这里我们只用DBMS_REDEFINITION对非区表完成分区转换,具体使用方法如下:

第一步:选择转换方法

    有两种选择,一种是建立主键,我的生产环境没有主键,那么我们只能选择rowid这种方法

第二步:检查表是否可以重定义

begin
  DBMS_REDEFINITION.CAN_REDEF_TABLE(uname        =>'orabpel',
                                    tname        =>'AUDIT_TRAIL',
                                    options_flag => dbms_redefinition.cons_use_rowid);
end;
说明:如果此不可重定义,直接会报不能重定义的原因,如果可以重定义,提示PL/SQL执行完成,红色选项是可选项,默认是按主键方法进行转换,因我操作的环境没有主键,那么只能选择rowid这种方法

第三步:创建转换临时表


说明:因10g不支持间隔分区,只能通过手工进行创建分区,图片只显示了部分内容,下面基本上一样,需要注意日期的写法,同时要注意分区只能将小的日期放在前面,大的放在后面,否则会报ORA-14037分区"AUDIT_TRAIL"分区界限过高!
第四步:设置并行操作

alter session force parallel dml parallel 4;
alter session force parallel query parallel 4;
因为我的表是90G,比较大,为加快处理速度设置并行执行,如果表比较小,这一步可以不要!

第五步:开始重定义表结构

BEGIN
  DBMS_REDEFINITION.START_REDEF_TABLE(uname       => 'orabpel',
                                      orig_table  => 'AUDIT_TRAIL',
                                      int_table   => 'AUDIT_TRAIL_EMP',
                                     options_flag => dbms_redefinition.cons_use_rowid

                                      ); --红色部分容易忽略
END;

注意:此过程比较消耗时间,会把中间表填满数据,所以此时要有足够的空间产生新中间表数据

第六步:同步临时表

BEGIN
  DBMS_REDEFINITION.SYNC_INTERIM_TABLE(uname      => 'orabpel',
                                       orig_table => 'AUDIT_TRAIL',
                                       int_table  => 'AUDIT_TRAIL_EMP'
                                       );
END;

--此过程比较快,只是同步从开始转换到现在产生的新数据

第七步:完成重定义

BEGIN
  DBMS_REDEFINITION.FINISH_REDEF_TABLE(uname      => 'orabpel',
                                       orig_table => 'AUDIT_TRAIL',
                                       int_table  => 'AUDIT_TRAIL_EMP'
                                       );
END;
第八步:删除临时表

BEGIN

  truncate table AUDIT_TRAIL_EMP;--大表不要忘记这步操作哦
  drop table AUDIT_TRAIL_EMP; --删除临时表的定义

END;

如果顺利的话到此就结束了,原表变成了分区表,在没有停业务的情况下完成了表的在线重定义,但是操作过程中往往没那么顺利,执行过程中报错怎么处理呢?

第九步:异常情况下终止操作

BEGIN

  DBMS_REDEFINITION.ABORT_REDEF_TABLE(uname      => 'orabpel',
                                      orig_table => 'AUDIT_TRAIL',
                                      int_table  => 'AUDIT_TRAIL_EMP'
                                      );
 END;

在执行任何一步出错,都可以执行第九步终止转换操作!

第十步:检查验证有效性

    做完以后一定要检查是否有失效对像

    select * from dba_objects where status<>'VALID' and owner='orabpel';

    发现有失效的包 ,处理方法

    alter package orabpel.collxa compile;

    处理完失效对像后查看最后一个分区的数据是否在增长,验证转换后分区是否可用

    select count(*) from orabpel.audit_trail_1309;

    发现数据并没有增长,肯定是那里出了问题,然后查看alert.log是否有报错

    发现报错如下:

    Some indexes or index [sub]partitions of table ORABPEL.AUDIT_TRAIL have been marked unusable

    处理方法如下:

  SELECT 'ALTER INDEX ' || INDEX_OWNER || '.' || INDEX_NAME ||
       'REBUILD PARTITION ' || PARTITION_NAME || ' NOLOGGING online;'
  FROM DBA_IND_PARTITIONS
 WHERE INDEX_OWNER NOT IN ('SYS', 'SYSTEM', 'PUBLIC')
   AND STATUS = 'UNUSABLE'
 UNION ALL
  SELECT 'alter index ' || OWNER || '.' || A.INDEX_NAME ||
       ' REBUILD online nologging;'
  FROM DBA_INDEXES A
 WHERE OWNER NOT IN ('SYS', 'SYSTEM', 'PUBLIC')
   AND STATUS = 'UNUSABLE';

   跟据执行结果执行,否则数据将不能正常写入,(切记!)

   alter index ORABPEL.CS_PK1 REBUILD online nologging;

   再次查询分区表数据是否正常写入 

   select count(*) from orabpel.audit_trail;

   发现数据增长很快,至此操作验证成功!

   总结:在线重定义并不能100%保证不影响业务,我在测试库上发现不影响业务,但是在正式库操作完以报最新分区表数据并没有增加,alert.log报上面的错误,处理完以后数据才正常写入,因此操作完以后一定要记得查看dba_objects去及时处理失效对像,同时查看alert.log是否有异常信息及时进行相应的处理,最后一定要验证最后一个分区表数据是否在增长,只能这样我们才能确认我们转换后的分区表是可用的!特别需要注意的是,如果你的库是10g的库,一定要及时增加分区,因为10g不支持间隔分区,需要人为手工的及时添加新的分区,如果在11g里面间隔分区可以做到自动添加新的分区,但是看表的DDL语句时发现并没有隔间分区的关键字,这就是为什么同样的语句在10g需要手工添加分区,而在11g却可以自动增加分区的原因。不知道为什么11g中间隔分区表DDL语句看不到间隔分区关键字,知道的朋友可以QQ交流一下!

dbms_redefinition在线重定义表结构 可以在表分区的时候使用的更多相关文章

  1. dbms_redefinition在线重定义表结构

    dbms_redefinition在线重定义表结构 (2013-08-29 22:52:58) 转载▼ 标签: dbms_redefinition 非分区表转换成分区表 王显伟 在线重定义表结构 在线 ...

  2. 基于 dbms_redefinition 在线重定义表

    Oracle 支持在线重定义表,也就是说我们可以在修改表结构(DDL)的同时进行相关的DQL.DML操作,使得前端的DML根本感觉不到表结构实际上已经发生了变化,对于用户而言是完全透明的.当然在线重定 ...

  3. Oracle在线重定义(online redefinition)--将普通表改为分区表

    使用Oracle的在线重定义技术,可以将Oracle的普通表改为分区表.操作如下: STEP1:测试表是否可以在线重定义,这里以unixdev数据库的LIJIAMAN.BSTEST为例 EXEC DB ...

  4. 在线重定义(Rdefine Table online)

    二.        概念理解 在线重定义用于对表的逻辑或者物理结构的修改,而且在修改时不影响表的可用性与传统方式相比.当一个表被重定义时,会被锁定为exclusive mode很短一段时间,这段时间的 ...

  5. Oracle在线重定义DBMS_REDEFINITION 普通表—>分区表

    实验环境:RHEL 6.4 + Oracle 11.2.0.3实验:在线重定义 普通表 为 分区表,包括主键对应的索引都改造为分区索引. 1,构造普通表t_objects conn test1/tes ...

  6. oracle在线重定义表

    在一个高可用系统中,如果需要改变一个表的定义是一件比较棘手的问题,尤其是对于7×24系统.Oracle提供的基本语法基本可以满足一般性修改,但是对于把普通堆表改为分区表,把索引组织表修改为堆表等操作就 ...

  7. 通过DBMS_REDEFINITION包对表在线重定义

    基础介绍 Oracle Online Redefinition可以保证在数据表进行DDL类型操作,如插入.删除数据列,分区处理的时候,还能够支持DML操作,特别是insert/update/delet ...

  8. (Oracle)已有数据表建立表分区—在线重定义

    今天在做数据抽取的时候,发现有一张业务表数据量达到了5000W,所以就想将此表改为分区表.分区表的有点如下: 1.改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度.2.增强可用性: ...

  9. Oracle 在线重定义表分区

    ==================原始表================原始表=====================原始表 create table BUILDING_temp(building ...

随机推荐

  1. 天梯赛 L2-001 紧急救援

    L2-001 紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速道 ...

  2. 简单两步 ~ 绕过 "Paused in debugger"

    不BB,上图 然后刷新一下就ok了~再也不能阻止我们查看源码了~ 补充:(屏蔽在Sources里面)

  3. Kafka学习之路

    一直在思考写一些什么东西作为2017年开篇博客.突然看到一篇<Kafka学习之路>的博文,觉得十分应景,于是决定搬来这“他山之石”.虽然对于Kafka博客我一向坚持原创,不过这篇来自Con ...

  4. 2018.02.12 noip模拟赛T2

    二兵的赌注 Description游戏中,二兵要进入了一家奇怪的赌场.赌场中有n个庄家,每个庄家都可以猜大猜小,猜一次一元钱.每一次开彩前,你都可以到任意个庄家那里下赌注.如果开彩结果是大,你就可以得 ...

  5. zabbix3.4 监控网卡流量设置差量

    自定义监控项的时候 看里面预设的监控网卡下载流量的key是 net.if.in[if,<mode>]这次可以监控流量了 但是添加监控项的时候 看网上别人的 都是可以设置数值是每秒的差量 出 ...

  6. (转)从一道面试题彻底搞懂hashCode与equals的作用与区别及应当注意的细节

    背景:学习java的基础知识,每次回顾,总会有不同的认识.该文系转载 最近去面试了几家公司,被问到hashCode的作用,虽然回答出来了,但是自己还是对hashCode和equals的作用一知半解的, ...

  7. (转)ZooKeeper的Znode剖析

    ZooKeeper的Znode剖析 https://blog.csdn.net/lihao21/article/details/51810395 根据节点的存活时间,可以对节点划分为持久节点和临时节点 ...

  8. Map.putAll方法——追加另一个Map对象到当前Map集合

    转: Map.putAll方法——追加另一个Map对象到当前Map集合(转) 该方法用来追加另一个Map对象到当前Map集合对象,它会把另一个Map集合对象中的所有内容添加到当前Map集合对象. 语法 ...

  9. 做错的题目——给Array附加属性

  10. CentOS 添加新的硬盘之后不停机操作

    echo "- - -" > /sys/class/scsi_host/host0/scan echo "- - -" > /sys/class/s ...