时间范围分区拆分
create table emp (
id number(6) not null,
hire_date date not null)
partition by range(hire_date)
(partition p_1998 values less than (to_date('1998-12-31','YYYY-MM-DD')),
partition p_1999 values less than (to_date('1999-12-31','YYYY-MM-DD')),
partition p_default values less than (maxvalue)
);

insert into emp values(10,to_date('1999-5-20','YYYY-MM-DD'));
insert into emp values(20,to_date('1999-8-10','YYYY-MM-DD'));

SQL> select count(*) from emp partition(p_1999);
  COUNT(*)
----------
         2
将p_1999分区拆分成两个分区
    
SQL> ALTER TABLE emp SPLIT PARTITION p_1999
  2     AT (to_date('1999-07-01','YYYY-MM-DD'))
  3     INTO (PARTITION p_1999_01, PARTITION p_1999_02);

表已更改。

SQL> select count(*) from emp partition(p_1999_01);

COUNT(*)
----------
         1

SQL> select count(*) from emp partition(p_1999_02);

COUNT(*)
----------
         1

将p_default分区拆分成两个分区

SQL> insert into emp values(30,to_date('2000-5-27','YYYY-MM-DD'));

已创建 1 行。

SQL> insert into emp values(40,to_date('2001-10-02','YYYY-MM-DD'));

已创建 1 行。

SQL> select count(*) from emp partition(p_default);

COUNT(*)
----------
         2

SQL> ALTER TABLE emp SPLIT PARTITION p_default
  2         AT (to_date('2000-12-31','YYYY-MM-DD'))
  3         INTO (PARTITION p_2000, PARTITION p_default);

表已更改。

SQL> select count(*) from emp partition(p_default);

COUNT(*)
----------
         1

SQL> select count(*) from emp partition(p_2000);

COUNT(*)
----------
         1

SQL> select * from emp partition(p_default);

ID HIRE_DATE
---------- -------------------
        40 2001-10-02 00:00:00

SQL> select * from emp partition(p_2000);

ID HIRE_DATE
---------- -------------------
        30 2000-05-27 00:00:00

LIST分区拆分
SQL> create table dept (
  2  id number(6) not null,
  3  area varchar2(15) not null)
  4  partition by list(area)
  5  (
  6     PARTITION asia VALUES ('CHINA', 'THAILAND'),
  7     PARTITION europe VALUES ('GERMANY', 'ITALY', 'SWITZERLAND'),
  8     PARTITION west VALUES ('AMERICA'),
  9     PARTITION east VALUES ('INDIA'),
 10     PARTITION rest VALUES (DEFAULT));

表已创建。

SQL> insert into dept values(10,'MEXICO');
已创建 1 行。

SQL> insert into dept values(20,'COLOMBIA');
已创建 1 行。

SQL> select count(*) from dept partition(rest);

COUNT(*)
----------
         2

SQL> ALTER TABLE dept SPLIT PARTITION rest
  2     VALUES ('MEXICO', 'COLOMBIA')
  3     INTO (PARTITION south, PARTITION rest);
表已更改。

SQL> select count(*) from dept partition(rest);

COUNT(*)
----------
         0

SQL> select count(*) from dept partition(south);

COUNT(*)
----------
         2

分区合并

SQL> SELECT table_name,partition_name  FROM USER_tab_partitions where table_name='EMP';

TABLE_NAME                     PARTITION_NAME
------------------------------ ------------------------------
EMP                            P_1998
EMP                            P_1999_01
EMP                            P_1999_02
EMP                            P_2000
EMP                            P_DEFAULT

SQL> ALTER TABLE emp
  2         MERGE PARTITIONS P_1999_01, P_1999_02 INTO PARTITION P_1999;

表已更改。

SQL> SELECT table_name,partition_name  FROM USER_tab_partitions where table_name='EMP';

TABLE_NAME                     PARTITION_NAME
------------------------------ ------------------------------
EMP                            P_1998
EMP                            P_1999
EMP                            P_2000
EMP                            P_DEFAULT

SQL> SELECT table_name,partition_name  FROM USER_tab_partitions where table_name='DEPT';

TABLE_NAME                     PARTITION_NAME
------------------------------ ------------------------------
DEPT                           ASIA
DEPT                           EUROPE
DEPT                           WEST
DEPT                           EAST
DEPT                           SOUTH
DEPT                           REST
已选择6行。

SQL> ALTER TABLE dept
  2     MERGE PARTITIONS south, rest INTO PARTITION rest;
表已更改。

SQL> select count(*) from dept partition(rest);

COUNT(*)
----------
         2

Oracle 11g 分区拆分与合并的更多相关文章

  1. oracle 11g 如何创建、修改、删除list-list组合分区

    Oracle11g在分区方面做了很大的提高,不但新增了4种复合分区类型,还增加了虚拟列分区.系统分区.INTERVAL分区等功能. 9i开始,Oracle就包括了2种复合分区,RANGE-HASH和R ...

  2. Oracle 11g新特性虚拟列分区

    如今有个需求:一个单据表要依照月份来分区.假设是在Oracle 10g上,仅仅能再加一个字段. 在Oracle 11g以后就不一样了.能够用虚拟列处理. SQL> select * from v ...

  3. oracle 11g 分区表创建(自动按年、月、日分区)

    前言:工作中有一张表一年会增长100多万的数据,量虽然不大,可是表字段多,所以一年下来也会达到 1G,而且只增不改,故考虑使用分区表来提高查询性能,提高维护性. oracle 11g 支持自动分区,不 ...

  4. Oracle 11g 的bug?: aix 上,expdp 11.2.0.1 导出,impdp 11.2.0.3 导入,Interval 分区的 【Interval】 分区属性成了【N】

    如题: Oracle 11g 的bug?: aix 上,expdp 11.2.0.1 导出,impdp 11.2.0.3 导入,Interval 分区的 [Interval] 分区属性成了[N] 谨记 ...

  5. oracle表分区以及普表转分区表(转)

    概述 Oracle的表分区功能通过改善可管理性.性能和可用性,从而为各式应用程序带来了极大的好处.通常,分区可以使某些查询以及维护操作的性能大大提高.此外,分区还可以极大简化常见的管理任务,分区是构建 ...

  6. Oracle 11g新特性

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

  7. oracle表分区详解

    原文来自:http://www.cnblogs.com/leiOOlei/archive/2012/06/08/2541306.html oracle表分区详解 从以下几个方面来整理关于分区表的概念及 ...

  8. Oracle 表分区

    从以下几个方面来整理关于分区表的概念及操作: 表空间及分区表的概念 表分区的具体作用 表分区的优缺点 表分区的几种类型及操作方法 对表分区的维护性操作 1.表空间及分区表的概念 表空间: 是一个或多个 ...

  9. oracle表空间表分区详解及oracle表分区查询使用方法(转+整理)

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

随机推荐

  1. gcc 内联汇编

    http://www.cnblogs.com/zhuyp1015/archive/2012/05/01/2478099.html

  2. 3D数学读书笔记——3D中的方位与角位移

    本系列文章由birdlove1987编写,转载请注明出处. 文章链接: http://blog.csdn.net/zhurui_idea/article/details/25339595 方位和角位移 ...

  3. jQuery碎语(4) 实用函数

    6.实用函数 ● 修剪字符串 $('#id').val($.trim($('#someid').val())) ● 遍历集合 可能这样写: var anArray = ['one','two']; f ...

  4. linux shell if语句使用方法

    原文地址:http://blog.chinaunix.net/uid-24607609-id-2118151.html 最精简的 if 命令的语法是: if TEST-COMMANDS; then C ...

  5. 树状结构 Tree data structure in C#

    delegate void TreeVisitor<T>(T nodeData); class NTree<T> { private T data; private Linke ...

  6. UML:概要设计,用什么画我的类图?

    背景 做过需求之后,很少使用 UML 画概要设计,这几天尝试的用了几个工具,最总还是选择了 VisualStudio. Edraw 详细信息很难编辑,如:签名. Viso 添加成员太麻烦了. Visu ...

  7. Android之判断当前网络状态

    /** * 检测网络是否可用 * @return */ public boolean isNetworkConnected() { ConnectivityManager cm = (Connecti ...

  8. 使用jquery操作iframe

    1. 内容里有两个ifame <iframe id="leftiframe"...</iframe> <iframe id="mainiframe ...

  9. 第七章 JVM性能监控与故障处理工具(1)

    1.定位系统问题 依据 GC日志 堆转储快照(heapdump/hprof文件) 线程快照(threaddump/javacore文件) 运行日志 异常堆栈 分析依据的工具 jps:显示指定系统内的所 ...

  10. 80端口占用异常解决方法java.net.BindException: Address already in use: JVM_Bind:80(或8080)

    1:Tomcat(或其他Web容器)启动时控制台报错如下示: 2007-8-2 15:20:43 org.apache.coyote.http11.Http11Protocol init 严重: Er ...