TRUNCATE [SUB]PARTITION和EXCHANGE [SUB]PARTITION命令如今可以包括CASCADE子句,从而允许参照分区表向下级联这些操作。为确保该选项正常,相关外键也必须包括DELETE子句。

1.        设置

下面创建一个分区父表(T1)和一个参照的分区子表(T2)。每个分区被插入一行数据。

DROP TABLE t2 PURGE;

DROP TABLE t1 PURGE;

CREATE TABLE t1 (

id           NUMBER,

info        VARCHAR2(50),

crt_dateDATE,

CONSTRAINT t1_pk PRIMARY KEY (id)

)

PARTITION BY RANGE (crt_date)

(PARTITION part_2014 VALUES LESS THAN(TO_DATE('01/01/2015', 'DD/MM/YYYY')) TABLESPACE users,

PARTITION part_2015 VALUES LESS THAN(TO_DATE('01/01/2016', 'DD/MM/YYYY')) TABLESPACE users);

CREATE TABLE t2 (

id             NUMBER NOT NULL,

t1_id          NUMBER NOT NULL,

info           VARCHAR2(50),

crt_date   DATE,

CONSTRAINT t2_pk PRIMARY KEY (id),

CONSTRAINTt2_t1_fk FOREIGN KEY (t1_id) REFERENCES t1 (id) ON DELETE CASCADE

)

PARTITION BY REFERENCE (t2_t1_fk);

INSERT INTO t1 VALUES (1, 't1 data',TO_DATE('05/05/2014', 'DD/MM/YYYY'));

INSERT INTO t1 VALUES (2, 't1 data',TO_DATE('05/05/2015', 'DD/MM/YYYY'));

INSERT INTO t2 VALUES (1, 1, 't2 data',TO_DATE('05/05/2014', 'DD/MM/YYYY'));

INSERT INTO t2 VALUES (2, 2, 't2 data',TO_DATE('05/05/2015', 'DD/MM/YYYY'));

COMMIT;

EXEC DBMS_STATS.gather_table_stats(USER,'t1');

EXEC DBMS_STATS.gather_table_stats(USER,'t2');

SELECT table_name,

partition_name,

num_rows

FROM  user_tab_partitions

ORDER BY 1,2;

TABLE_NAME           PARTITION_NAME         NUM_ROWS

-------------------- ------------------------------

T1                   PART_2014                     1

T1                   PART_2015                     1

T2                   PART_2014                     1

T2                   PART_2015                     1

SQL>

2.        TRUNCATE PARTITION ... CASCADE

通过TRUNCATE PARTITION ... CASCADE命令,我们可以清空父表分区和子表分区。

ALTER TABLE t1 TRUNCATE PARTITION part_2014CASCADE UPDATE INDEXES;

EXEC DBMS_STATS.gather_table_stats(USER,'t1');

EXEC DBMS_STATS.gather_table_stats(USER, 't2');

SELECT table_name,

partition_name,

num_rows

FROM  user_tab_partitions

ORDER BY 1,2;

TABLE_NAME           PARTITION_NAME         NUM_ROWS

-------------------- ------------------------------

T1                   PART_2014                     0

T1                   PART_2015                     1

T2                   PART_2014                     0

T2                   PART_2015                     1

SQL>

3.        EXCHANGE PARTITION ... CASCADE

为了测试EXCHANGE PARTITION ...CASCADE命令,创建如下非分区表。为确保层级功能正常,从交换级别开始往下的所有表必须存在。

DROP TABLE t2_temp;

DROP TABLE t1_temp;

CREATE TABLE t1_temp (

id           NUMBER,

info  VARCHAR2(50),

crt_dateDATE,

CONSTRAINT t1_temp_pk PRIMARY KEY (id)

);

CREATE TABLE t2_temp (

id             NUMBER NOT NULL,

t1_id          NUMBER NOT NULL,

info    VARCHAR2(50),

crt_date   DATE,

CONSTRAINT t2_temp_pk PRIMARY KEY (id),

CONSTRAINT t2_temp_t1_temp_fk FOREIGN KEY (t1_id) REFERENCES t1_temp(id) ON DELETE CASCADE

);

INSERT INTO t1_temp VALUES (2, 't1_temp data',TO_DATE('05/05/2015', 'DD/MM/YYYY'));

INSERT INTO t2_temp VALUES (2, 2, 't2_tempdata', TO_DATE('05/05/2015', 'DD/MM/YYYY'));

COMMIT;

如下交换父表和子表分区后,检查表中数据。

-- 交换分区

ALTER TABLE t1

EXCHANGE PARTITION part_2015

WITHTABLE t1_temp

CASCADE

UPDATEINDEXES;

-- 检查分区中的数据

COLUMN t1_info FORMAT A20

COLUMN t2_info FORMAT A20

SELECT t1.info AS t1_info,

t2.info AS t2_info

FROM  t1

JOIN t2 ON t2.t1_id = t1.id;

T1_info              T2_info

-------------------- --------------------

t1_temp data          t2_temp data

SQL>

-- 检查临时表中的数据。

COLUMN t1_temp_info FORMAT A20

COLUMN t2_temp_info FORMAT A20

SELECT t1_temp.info AS t1_temp_info,

t2_temp.info AS t2_temp_info

FROM  t1_temp

JOIN t2_temp ON t2_temp.t1_id = t1_temp.id;

T1_TEMP_info         T2_TEMP_info

-------------------- --------------------

t1 data               t2 data

SQL>

Oracle12c中分区(Partition)新特性之TRUNCATEPARTITION和EXCHANGE PARTITION级联功能的更多相关文章

  1. Oracle12c中数据泵新特性之功能增强(expdp, impdp)

    Oracle的数据泵功能在10g中被引进.本文对数据泵在12c中的增强做一个概览. 1.   禁用日志选项(DISABLE_ARCHIVE_LOGGING) Impdp的TRANSFORM参数已经扩展 ...

  2. Oracle12c中性能优化新特性之新增APPROX_COUNT_DISTINCT 快速唯一值计数函数

    Oracle11g中,为了改善DBMS_STATS包收集统计信息时的唯一值计数功能,增加了 APPROX_COUNT_DISTINCT函数,但文档中未记载.Oracle12c文档中包括了该函数,因此, ...

  3. Jdk5.0中出现的新特性

    掌握jdk5.0中出现的新特性1.泛型(Generics)2.增强的"for"循环(Enhanced For loop)3.自动装箱/自动拆箱(Autoboxing/unboxin ...

  4. MVC中的其他新特性

    MVC中的其他新特性 (GlobalImport全局导入功能) 默认新建立的MVC程序中,在Views目录下,新增加了一个_GlobalImport.cshtml文件和_ViewStart.cshtm ...

  5. C#6.0 中的那些新特性

    C#6.0 中的那些新特性 前言 VS2015在自己机器上确实是装好了,费了老劲了,想来体验一下跨平台的快感,结果被微软狠狠的来了一棒子了,装好了还是没什么用,应该还需要装Xarmain插件,配置一些 ...

  6. iOS中的项目新特性页面的处理

    一般项目中都会出现新特性页面,比如第一次使用应用的时候,或者在应用设置里查看新特性的时候会出现. 这里,选择新建一个专门处理项目新特性的控制器,来完成功能. 首先是 NewFeaturesViewCo ...

  7. Xcode中StoryBoard Reference 新特性的使用

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  8. 浅析Oracle 12c中Data Guard新特性

    浅析Oracle 12c中Data Guard新特性   写在前面 无论是做Oracle运维的小伙伴还是老伙伴,想必对Oracle数据库的数据级灾备核心技术—Data Guard是再熟悉不过了!这项从 ...

  9. ES6系列之项目中常用的新特性

    ES6系列之项目中常用的新特性 ES6常用特性 平时项目开发中灵活运用ES6+语法可以让开发者减少很多开发时间,提高工作效率.ES6版本提供了很多新的特性,接下来我列举项目中常用的ES6+的特性: l ...

随机推荐

  1. 网站开发进阶(二十九)HTML特殊转义字符

    HTML特殊转义字符 参考文献 http://tool.oschina.net/commons?type=2 美文美图

  2. Android轶事之View要去大保健?View大小自己决定?

    -"爹,我要吃糖" -"好哒儿子" -"爹,我要吃包包" - "好哒儿子" - "爹,我要吃串串" ...

  3. Mahout 系列之----共轭梯度

    无预处理共轭梯度 要求解线性方程组 ,稳定双共轭梯度法从初始解 开始按以下步骤迭代: 任意选择向量 使得 ,例如, 对 若 足够精确则退出 预处理共轭梯度 预处理通常被用来加速迭代方法的收敛.要使用预 ...

  4. android使用ViewPager实现欢迎引导页

    android使用ViewPager实现欢迎引导页 大多数APP第一次启动的时候,都会有一个引导界面,左右滑动,到最后一张,用户点击才再次进入主界面.当第二次启动的时候,则直接进入主界面. 这种效果一 ...

  5. “《编程珠玑》(第2版)第2章”:C题(查找变位词,排序)

    C题是这样子的: 给定一个英语字典,找出其中的所有变位词集合.例如,“pots”.“stop”和“tops”互为变位词,因为每一个单词都可以通过改变其他单词中字母的顺序来得到. 下段分析摘自该书(P1 ...

  6. 不错的网络协议栈测试工具 — Packetdrill

    Packetdrill - A network stack testing tool developed by Google. 项目:https://code.google.com/p/packetd ...

  7. Java中如何封装自己的类,建立并使用自己的类库?

    from:http://blog.csdn.net/luoweifu/article/details/7281494 随着自己的编程经历的积累会发现往往自己在一些项目中写的类在别的项目中也会有多次用到 ...

  8. linux下显示不规则图片窗口

    测试环境是ubuntu15.04,使用的图形库是gtk+. 图片格式采用的是X11的xpm格式,首先从网上找一个背景透明的png图片,然后用图形转换工具(比如gimp)转换为xpm格式. 程序代码如下 ...

  9. Android特效专辑(三)——自定义不一样的Toast

    Android特效专辑(三)--自定义不一样的Toast 大家都知道,Android的控件有时候很难满足我们的需求,所以我们需要自定义View.自定义的方式很多,有继承原生控件也有直接自定义View的 ...

  10. 关于getchar函数缓冲区的问题

    最近,看到有同学问我关于getchar()这个函数缓冲区的问题,结合我以前的学习,我将对getchar()进行一次总结,当然,这些都是别人已经提过的东西,我只是总结,接下来我们来看看. 首先,用get ...