使用Oracle的在线重定义技术,可以将Oracle的普通表改为分区表。操作如下:

STEP1:测试表是否可以在线重定义,这里以unixdev数据库的LIJIAMAN.BSTEST为例

 EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE('LIJIAMAN','BSTEST', DBMS_REDEFINITION.CONS_USE_PK);

如果表上没有主键,则会报错:
SQL> exec dbms_redefinition.start_redef_table('LIJIAMAN', 'BSTEST', 'BSTEST_TMP');
ORA-12089: 不能联机重新定义无主键的表 "LIJIAMAN"."BSTEST"
ORA-06512: 在 "SYS.DBMS_REDEFINITION", line 56
ORA-06512: 在 "SYS.DBMS_REDEFINITION", line 1498
ORA-06512: 在 line 1

STEP2:创建中间表
除了表名称外,该中间表的形式需要与我们最终的分区表的形式一模一样,如列名,列的数据类型、分区字段,分区方法等。

如果要删除列,请不要在临时表的定义中包括它们。如果要添加列,则将列定义添加到临时表中。如果要修改列,请使用所需的属性在临时表中创建它。

不必使用重新定义该表的所有索引,约束,授予和触发器来创建临时表,因为在复制相关对象时,这些将在步骤5中定义。

create table BSTEST_tmp
( TIMEKEY VARCHAR2(40),
ITEMNAME VARCHAR2(40),
SITENAME VARCHAR2(40),
SITEVALUE VARCHAR2(40)
)
partition by range (timekey)
( partition part_201711 values less than(''),
partition part_201712 values less than(''),
partition part_201801 values less than(''),
partition part_201802 values less than(''),
partition part_201803 values less than(''),
partition part_201804 values less than(''),
partition part_201805 values less than(''),
partition part_201806 values less than(''),
partition part_201807 values less than(''),
partition part_201808 values less than(''),
partition part_201809 values less than(''),
partition part_201810 values less than(''),
partition part_201811 values less than(''),
partition part_201812 values less than(''),
partition part_201901 values less than(''),
partition part_201902 values less than(''),
partition part_201903 values less than(''),
partition part_201904 values less than(''),
partition part_201905 values less than(''),
partition part_201906 values less than(''),
partition part_201907 values less than(''),
partition part_201908 values less than(''),
partition part_201909 values less than(''),
partition part_201910 values less than(''),
partition part_201911 values less than(''),
partition part_201912 values less than(''),
partition part_202001 values less than(''),
partition part_202002 values less than(''),
partition part_202003 values less than(''),
partition part_202004 values less than(''),
partition part_max values less than(maxvalue)
);

STEP3:执行在线重定义

exec dbms_redefinition.start_redef_table('LIJIAMAN', 'BSTEST', 'BSTEST_TMP');

备注:该步骤执行时间较长,3.7GB的表执行了60s

STEP4:[可选] 将中间表的内容与数据源同步,减少执行“结束在线重定义”的时间

execute dbms_redefinition.sync_interim_table('LIJIAMAN', 'BSTEST', 'BSTEST_TMP');

STEP5:添加索引,约束,授权和触发器

使用以下两种方法之一,将要重新定义的表中的依赖对象(例如触发器,索引,实例化视图日志,授权和约束)和统计信息复制到临时表中。方法1是首选方法,因为它比较自动,但是有时您可能会选择使用方法2。方法1还使您能够将表统计信息复制到临时表中。

方法1:自动创建从属对象
使用该COPY_TABLE_DEPENDENTS过程可在临时表上自动创建相关对象。此过程还注册从属对象。注册从属对象可以使这些对象及其复制的对等对象的身份稍后在重新定义完成过程中自动交换。结果是,重新定义完成后,从属对象的名称将与原始从属对象的名称相同。

DECLARE
num_errors PLS_INTEGER;
BEGIN
DBMS_REDEFINITION.COPY_TABLE_DEPENDENTS('LIJIAMAN', 'BSTEST', 'BSTEST_TMP',DBMS_REDEFINITION.CONS_ORIG_PARAMS, TRUE, TRUE, TRUE, TRUE, num_errors);
END;
/

查看是否有错误信息:

select object_name, base_table_name, ddl_txt from   DBA_REDEFINITION_ERRORS;

方法2:手动创建从属对象
您可以在临时表上手动创建依赖对象。

alter table BSTEST add constraint BSPANELPROCESSDATAITEM_PKS primary key(timekey,itemname,sitename) using index local tablespace users;

STEP6:结束在线重定义

exec dbms_redefinition.finish_redef_table('LIJIAMAN', 'BSTEST', 'BSTEST_TMP');

STEP7:收集统计信息

exec dbms_stats.gather_table_stats(ownname=>'LIJIAMAN', tabname=>'BSTEST', method_opt=> 'FOR ALL INDEXED COLUMNS', estimate_percent => 10, cascade=>true);

备注:该步骤执行时间较长,3.7GB的表执行了36s,如果嫌慢,可以并行收集

STEP8:确认无误之后,删除STEP2创建的中间表

drop table BSTEST_TMP;

===========================

回退操作:如果执行过程中发生错误,可以使用以下语句回退

BEGIN
DBMS_REDEFINITION.ABORT_REDEF_TABLE(uname => 'LIJIAMAN',
orig_table => 'BSTEST',
int_table => 'BSTEST_TMP');
END;
/

如果要了解在线重定义的详细用法及使用注意事项,可参阅官方文档:
1. https://docs.oracle.com/cd/E11882_01/server.112/e25494/tables.htm#ADMIN11677
2. How To Partition Existing Table Using DBMS_REDEFINITION (文档 ID 472449.1)

Oracle在线重定义(online redefinition)--将普通表改为分区表的更多相关文章

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

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

  2. oracle在线重定义表

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

  3. Oracle 在线重定义表分区

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

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

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

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

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

  6. Oracle大表改为分区表及表空间切换方案

    Oracle大表改为分区表及表空间切换方案 一.            背景 由于之前数据库表和索引放在一个表空间导致表空间数据文件增长太快,文件数量即将达到Oracle表空间的限制,需要对表(没有分 ...

  7. oracle 11g 将非分区表转换为分区表在线重定义

    --操作的用户需要有以下的权限 GRANT CONNECT, RESOURCE TO CMIGDW; GRANT EXECUTE ON DBMS_REDEFINITION TO CMIGDW; GRA ...

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

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

  9. oracle普通表转分区表(在线重定义方式)

    1.1.TAB_TAOBAO_BILL 1.1.1检查下这张表是否可以在线重定义,无报错表示可以,报错会给出错误信息: exec dbms_redefinition.can_redef_table(' ...

随机推荐

  1. css3阴影

    <!DOCTYPE html> <html> <head> <style> div { margin-top:100px; margin-left:10 ...

  2. hdu 1159 Common Subsequence(LCS)

    Common Subsequence Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  3. 使用qt帮助 查看样式表stylesheet的帮助文档

    QCreactor帮助文档中搜索的关键字 Qt Style Sheets Examples        有所有控件的样式例子 Qt Style Sheets Reference      控件的所有 ...

  4. 解决 sourcetree git ssh私钥问题

    最近遇到个问题,git仓库用gitbash,更新和提交都是没问题的,用界面化工具SourceTree就一直提示下面信息: git -c diff.mnemonicprefix=false -c cor ...

  5. C++异常安全

    转自:http://www.cnblogs.com/zgfLawliet/p/3417308.html   异常安全的代码是指,满足两个条件 1异常中立性 : 是指当你的代码(包括你调用的代码)引发异 ...

  6. Python初学者第十天 集合、十六进制

    10day 数据类型:集合 set 1.集合的定义 集合:无序的.不重复的数据组合. 特性:a.去重,把一个列表变成集合,就自动去重了 b.关系测试.测试两组数据之间的交集.差集.并集等关系 2.集合 ...

  7. ADOBE READER把PDF转换成WORD教程

    目前国外很多软件的支持信息都使用PDF方式进行发布,如果没有Adobe  Reader,无法查看其内容,如果没有相关的编辑软件又无法编辑PDF文件.转换为DOC格式则可以实现编辑功能.尽管有些软件也可 ...

  8. LDA相关论文汇总

    转:http://blog.csdn.net/pirage/article/details/9467547 LDA理论 David M. Blei, Andrew Y. Ng, and Michael ...

  9. 1874 football game(三分法and method to compute the area of trianngle)

    FInd the max area. 1. 三分法 2. NAN (not comparable with number) http://acm.timus.ru/problem.aspx?space ...

  10. dynamic_cast动态转换

    我们都知道dynamic_cast会在运行时进行类型检查,比较安全,static_cast静态转换,不安全 dynamic_cast转换的类型必须是个类,且这个类中必须有虚函数,为什么呢? 虚函数对于 ...