分区(Partition)一直是Oracle数据库引以为傲的一项技术,正是分区的存在让Oracle高效的处理海量数据成为可能,在Oracle 11g中,分区技术在易用性和可扩展性上再次得到了增强。在10g的Oracle版本中,要对分区表做调整,尤其是对RANGE分区添加新的分区都需要DBA手动定期添加,或都使用存储过程进行管理。在11G的版本中的Interval Partition不再需要DBA去干预新分区的添加,Oracle会自动去执行这样的操作,减少了DBA的工作量。Interval Partition是Range分区的一个扩展。

1、Extended Composite Partitioning

In previous releases of Oracle, composite partitioning was limited to Range-Hash and Range-List partitioning. Oracle 11g Release 1 extends this to allow the following composite partitioning schemes:

Range-Hash (available since 8i)
Range-List (available since 9i)
Range-Range
List-Range
List-Hash
List-List

2、使用Interval Partition也有一些限制

 You can only specify one partitioning key column, and it must be of NUMBER or DATE type.
 Interval partitioning is not supported for index-organized tables.
 You cannot create a domain index on an interval-partitioned table.
 Interval partitioning is not supported at the subpartition level. ...

3、Interval Partition也可以创建复合分区

 Interval-range
 Interval-hash
 Interval-list
 

4、复合分区例子

1) Interval-list
-- Create table
--drop table ISMP.GWTRXS purge;
create table ISMP.GWTRXS
(
  GWORDERS_ID           VARCHAR2(22),
  TRXNUM                VARCHAR2(128) not null,
  TRXTYPE               VARCHAR2(4) not null,
  CHANNEL               VARCHAR2(2) not null,
  PAYMENT_TYPE          VARCHAR2(2) not null,
  PAYMODE               VARCHAR2(2) not null,
  AMOUNT                NUMBER not null,
  CURRENCY              VARCHAR2(4) not null,
  SERVICECODE           VARCHAR2(20),
  ACQUIRER_CODE         VARCHAR2(30) not null,
  ACQUIRER_NAME         VARCHAR2(400),
  ACQUIRER_MERCHANT     VARCHAR2(64) not null,
  ACQUIRER_SEQ          VARCHAR2(128),
  ACQUIRER_DATE         VARCHAR2(8),
  ACQUIRER_MSG          VARCHAR2(256),
  SUBMITDATES           VARCHAR2(20) not null,
  PAYER_IP              VARCHAR2(20),
  REFNUM                VARCHAR2(128),
  AUTHCODE              VARCHAR2(6),
  FROMACCTID            VARCHAR2(22),
  FROMACCTNUM           VARCHAR2(256) not null,
  BUYER_ID              VARCHAR2(22),
  BUYER_NAME            VARCHAR2(64),
  PAYINFO               VARCHAR2(64),
  CREATEDATE            DATE not null,
  CLOSEDATE             DATE not null,
  TRXSTS                VARCHAR2(3) not null,
  OPERS                 VARCHAR2(128),
  OPERDATE              DATE not null,
  VERSION               NUMBER not null,
  TRXDESC               VARCHAR2(100),
  ID                    VARCHAR2(22) not null,
  ACQUIRER_ID           VARCHAR2(20),
  FEE_AMOUNT            NUMBER,
  TRADE_NO              VARCHAR2(255 CHAR),
  SUCCESS_TYPE          VARCHAR2(255 CHAR),
  CHANNEL_RESPONSE      VARCHAR2(511),
  CHANNEL_RESULT        VARCHAR2(20),
  CHANNEL_RESPONSE_TIME VARCHAR2(20),
  DBTYPE                VARCHAR2(30)
)
partition by range (CREATEDATE) INTERVAL (numtodsinterval(1,'day'))
subpartition by list (DBTYPE)
SUBPARTITION TEMPLATE
(SUBPARTITION sub1 VALUES ('bailian'),
 SUBPARTITION sub2 VALUES ('yisheng'),
 SUBPARTITION sub3 VALUES ('mpayys'),
 SUBPARTITION sub4 VALUES ('yixuan'),
 SUBPARTITION sub5 VALUES ('yixuan17'),
 SUBPARTITION sub6 VALUES ('xifupay'),
 SUBPARTITION other VALUES (DEFAULT))
(partition P1 values less than (TO_DATE(' 2011-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', 'NLS_CALENDAR=GREGORIAN')));
 
2)增加子分区模板
注意:新增的子分区模板,只有新的分区生成时,才会被使用到,旧的分区的子分区无法根据新的模板进行分裂,
因此,模板中要保留default分区。
ALTER table ismp.gworders SET
SUBPARTITION TEMPLATE (
SUBPARTITION sub1 VALUES ('bailian'),
 SUBPARTITION sub2 VALUES ('yisheng'),
 SUBPARTITION sub3 VALUES ('mpayys'),
 SUBPARTITION sub4 VALUES ('yixuan'),
 SUBPARTITION sub5 VALUES ('yixuan17'),
 SUBPARTITION sub6 VALUES ('xifupay'),
 SUBPARTITION sub7 VALUES ('nfooo'),
 SUBPARTITION other VALUES (DEFAULT)
);

原文:https://blog.csdn.net/jolly10/article/details/82620802

Oracle 11g新特性 Interval Partition的更多相关文章

  1. Oracle 11g 新特性 --SQL Plan Management 说明

    Oracle 11g 新特性 --SQL Plan Management 说明 参见大神博主文章: http://blog.csdn.net/tianlesoftware/article/detail ...

  2. Oracle 11g 新特性 – HM(Hang Manager)简介

    在这篇文章中我们会对oracle 11g 新特性—hang 管理器(Hang Manager) 进行介绍.我们需要说明,HM 只在RAC 数据库中存在. 在我们诊断数据库问题的时候,经常会遇到一些数据 ...

  3. 使用Oracle 11g新特性 Active Database Duplication 搭建Dataguard环境

    Duplication Database 介绍 Duplicate database可以按照用途分为2种: duplicate database(复制出一个数据库) duplicate standby ...

  4. Oracle 11g新特性

    文章转自网络 Oracle 11g于2007年7月11日美国东部时间11时(北京时间11日22时)正式发布,11g是甲骨文公司30年来发布的最重要的数据库版本,根据用户的需求实现了信息生命周期管理(I ...

  5. Oracle 11g 新特性(一)-- 虚拟列

    数据库版本: Oracle Database 11g Enterprise Edition Release 11.2.0.2.0 - 64bit Oracle11g 增加了虚拟列的新特性, 具体说明如 ...

  6. Oracle 11g新特性延迟段创建和truncate的增强

    下面测试Oracle 11g开始的新特性truncate的增强和延迟段空间创建. Oracle从11g开始,当用户创建一张空表的时候不会先分配段和空间,只有当对这张表插入第一行数据的时候才分配段和空间 ...

  7. Oracle 11g新特性 -- 延迟段

    11gR2之前的版本中,当创建一张表时,会自动分配段空间,这样做有几个弊端: 1. 初始创建表时就需要分配空间,自然会占用一些时间,如果初始化多张表,这种影响就被放大. 2. 如果很多表开始的一段时间 ...

  8. Oracle 11g 新特性 -- Oracle Restart 说明(转载)

    转载:http://blog.csdn.net/tianlesoftware/article/details/8435670 一.  OHASD 说明 Oracle 的Restart 特性是Oracl ...

  9. Oracle 11g新特性direct path read引发的系统停运故障诊断处理

    黎俊杰 | 2016-07-28 14:37 声明:部分表名为了脱敏而用XX代替 1.故障现象 (1)一个业务系统输入用户名与密码后无法进入首页,表现为一直在运行等待,运行缓慢 (2)整个系统无法正常 ...

随机推荐

  1. Go第四篇之流程控制

    流程控制是每种编程语言控制逻辑走向和执行次序的重要部分,流程控制可以说是一门语言的“经脉”. Go 语言的常用流程控制有 if 和 for,而 switch 和 goto 主要是为了简化代码.降低重复 ...

  2. UNIX系统的显示时间何时会到尽头

    本文转载自:http://www.cnblogs.com/dfcao/p/expertCprogramming_intr0.html 本文分为三个小块: 一.UNIX系统中时间的存储形式: 二. ti ...

  3. C#预处理器指令【转】

    本文转载自:http://www.cnblogs.com/miffylf/p/4005223.html C#有许多名为预处理器指令的命令.这些命令从来不会转化为可执行代码中的命令,但会影响编译过程的各 ...

  4. Linq let Concat

    let: String[] strs = { "A penny saved is a penny earned.", "The early bird catches th ...

  5. Linq in GroupBy GroupJoin

    还是上一份的代码例子: public class Person { public int ID { get; set; } public string Name { get; set; } publi ...

  6. 再谈树---无根树转有根树( dfs搜索转化+fa数组记录父节点) *【模板】

    #include <stdio.h> #include <string.h> #include <stdlib.h> #include <vector> ...

  7. 2016年蓝桥杯B组C/C++省赛(预选赛)试题

    2016年蓝桥杯B组C/C++ 点击查看2016年蓝桥杯B组省赛题目解析(答案) 第一题:煤球数目 有一堆煤球,堆成三角棱锥形.具体: 第一层放1个, 第二层3个(排列成三角形), 第三层6个(排列成 ...

  8. python 删除列表中的字典元素

    data={"} ,{"}]} print("before:\n\n",data,"\n\n") temp=- k= for i in da ...

  9. Could NOT find SDL_image (missing:SDL_IMAGE_LIBRARIES SDL_IMAGE_INCLUDE_DIRS)

    sudo apt-get install libsdl-image1.2-dev

  10. VC6的VCVARS32.BAT所在位置

    1. C:\Program Files (x86)\Microsoft Visual Studio\VC98\Bin\VCVARS32.BAT 2.