如何进行分区表split操作及maxvalue处理

这篇文章将为大家详细讲解有关如何进行分区表split操作及maxvalue处理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

我们提供的服务有:成都做网站、网站设计、微信公众号开发、网站优化、网站认证、曲麻莱ssl等。为上千多家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的曲麻莱网站制作公司

CREATE TABLE DFMS.WIP_D_WO_DETAIL
(
  WORK_ORDER          VARCHAR2(25 CHAR)         NOT NULL,
  PART_NO             VARCHAR2(35 BYTE)         NOT NULL,
  PART_REV            VARCHAR2(10 BYTE)         DEFAULT 'N/A'                 NOT NULL,
  ALT_FLAG            VARCHAR2(1 BYTE)          DEFAULT '0'                   NOT NULL,
  SUBSTITUTE_PN       VARCHAR2(35 BYTE),
  UNIT_QTY            NUMBER                    DEFAULT 0                     NOT NULL,
  SOURCE_DEPT         VARCHAR2(5 BYTE)          DEFAULT 'SFC'                 NOT NULL,
  CREATOR             VARCHAR2(20 BYTE)         NOT NULL,
  CREATE_DATE         DATE                      DEFAULT SYSDATE,
  UPDATER             VARCHAR2(20 BYTE),
  UPDATE_DATE         DATE,
  SCH_PART_NO         VARCHAR2(35 BYTE),
  MAIN_WHID           VARCHAR2(10 BYTE),
  REPLACE_GROUP       VARCHAR2(50 BYTE)         NOT NULL,
  MOD_NO              VARCHAR2(20 BYTE),
  PHANTOM_FLAG        VARCHAR2(10 BYTE)
)
TABLESPACE PART_D_TS1
PCTUSED    0
PCTFREE    10
INITRANS   1
MAXTRANS   255
LOGGING
PARTITION BY RANGE (CREATE_DATE)

  PARTITION P200907 VALUES LESS THAN (TO_DATE(' 2009-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201001 VALUES LESS THAN (TO_DATE(' 2010-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201007 VALUES LESS THAN (TO_DATE(' 2010-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201101 VALUES LESS THAN (TO_DATE(' 2011-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201107 VALUES LESS THAN (TO_DATE(' 2011-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201201 VALUES LESS THAN (TO_DATE(' 2012-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201207 VALUES LESS THAN (TO_DATE(' 2012-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION P201301 VALUES LESS THAN (TO_DATE(' 2013-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

'NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               ), 
  PARTITION PMAX VALUES LESS THAN (MAXVALUE)
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               )
)
NOCOMPRESS
NOCACHE
NOPARALLEL
MONITORING
ENABLE ROW MOVEMENT; 


假设没有maxvalue部分,那么加入分区: 


ALTER TABLE DFMS.WIP_D_WO_DETAIL
ADD PARTITION P201307 VALUES LESS THAN (TO_DATE(' 2013-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

NLS_CALENDAR=GREGORIAN'))
    LOGGING
    NOCOMPRESS
    TABLESPACE PART_D_TS1
    PCTFREE    10
    INITRANS   1
    MAXTRANS   255
    STORAGE    (
                INITIAL          50M
                NEXT             50M
                MINEXTENTS       1
                MAXEXTENTS       UNLIMITED
                PCTINCREASE      0
                BUFFER_POOL      DEFAULT
               )  ;

这里有maxvalue部分,那么加入分区需要split : 

备注: 
split partition时,根据split point原来的partition分裂成两个partition。
如果其中一个partition是空的,则不需要move原来的partition,也不需要rebuild
index,这种我们称之为fast split。

不过如果在split的时候指定了tablespace,即使其中一个partition是空的,而且该
tablespace与parent partition的tablespace不同,oracle会move整个partition到
新的tablespace中。因为这个tablespace参数,导致了原来的fast split不成功,而
需要move segment和rebuild index。

ALTER TABLE DFMS.WIP_D_WO_DETAIL
SPLIT PARTITION  PMAX  AT (TO_DATE(' 2013-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', NLS_CALENDAR=GREGORIAN'))
INTO  (PARTITION  P201307  TABLESPACE PART_D_TS1, PARTITION  PMAX  TABLESPACE  PART_D_TS1) ;

如果你需要取消maxvalue部分,那么split几部分后,查看最后一部分是否有值,如果没有,直接
drop掉最后split出去的那部分。 然后就可以直接add partition 了。

ALTER TABLE DFMS.WIP_D_WO_DETAIL
SPLIT PARTITION  PMAX  AT (TO_DATE(' 2013-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', NLS_CALENDAR=GREGORIAN'))
INTO  (PARTITION  P201307  TABLESPACE PART_D_TS1, PARTITION  P2014  TABLESPACE  PART_D_TS1) ;

ALTER TABLE DFMS.WIP_D_WO_DETAIL
SPLIT PARTITION  P2014  AT (TO_DATE(' 2014-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', NLS_CALENDAR=GREGORIAN'))
INTO  (PARTITION  P201401  TABLESPACE PART_D_TS1, PARTITION  P201407  TABLESPACE  PART_D_TS1) ;

ALTER TABLE DFMS.WIP_D_WO_DETAIL
SPLIT PARTITION  P201407  AT (TO_DATE(' 2014-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS', NLS_CALENDAR=GREGORIAN'))
INTO  (PARTITION  P201407  TABLESPACE PART_D_TS1, PARTITION  P201501  TABLESPACE  PART_D_TS1) ;

ALTER TABLE DFMS.WIP_D_WO_DETAIL DROP PARTITION  P201501  ;

然后就可以类似没有设置maxvalue一样加入后面的partiton .

ALTER TABLE DFMS.WIP_D_WO_DETAIL
ADD PARTITION P201501 VALUES LESS THAN (TO_DATE(' 2015-01-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

NLS_CALENDAR=GREGORIAN')) ;

ALTER TABLE DFMS.WIP_D_WO_DETAIL
ADD PARTITION P201507 VALUES LESS THAN (TO_DATE(' 2015-07-01 00:00:00', 'SYYYY-MM-DD HH24:MI:SS',

NLS_CALENDAR=GREGORIAN')) ;

..... 


如果在split的时候将tablespace更换了,那么需要rebuild index .

下面的语句用于rebuild local index partitions或子分区
(子分区一般指range-hash等组合分区中的子分区) : 
ALTER INDEX ... REBUILD PARTITION/SUBPARTITION


ALTER TABLE ... MODIFY PARTITION/SUBPARTITION ... REBUILD UNUSABLE LOCAL INDEXES
这个语句找出所有的unusable的index, 然后rebuild他们。

关于如何进行分区表split操作及maxvalue处理就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


当前文章:如何进行分区表split操作及maxvalue处理
本文网址:http://pcwzsj.com/article/ipdeop.html