[转自] http://www.linuxidc.com/Linux/2011-07/38381.htm

Oracle分区表的管理笔记(仅限于对普通表,即堆表的分区管理,IOT跟CLUSTER TABLE不再讨论范围内)

1. 增加分区(add partition)

语法是:alter table xxx add partition…

需要注意的是如果分区中存在maxvalue或default分区add partition会报错,应使用split

如:

Alter table t_range add partition p5 values less than (50) [tablespace users];

--50 要大于之前分区的所有值

Alter table t_list add partition p5 values (7,8,9) [tablespace users];

--7,8,9均不能在之前分区中出现

Alter table t_hash add partition [p5] [tablespace users];

增加子分区:

Alter table xxx modify partition p1 add subpartition …

如:增加RANGE-HASH子分区

ALTER TABLE diving MODIFY PARTITION locations_us

      ADD SUBPARTITION us_locs5 TABLESPACE us1;

Range,list增加分区不会影响索引(包括global 跟local),HASH增加分区会让数据重新分配,产生IO,如果不指定update indexes 选项则会导致有数据移动的索引unusable,需要重新编译。

当然,我们说的对索引的影响都是在表中有数据的情况下,没数据当然影响不到索引了。

2. 合并分区(coalesce partition)

   Alter table xxx coalesce partion [update indexes];

   Alter table xxx modify partition p1 coalesce subpartition;

   仅适用于HASH分区或子分区,合并一次会减少一个分区(最少能减少到1个),数据重新分配,产生IO,有数据移动的索引失效(如果不指定update indexes的话).

3. 删除分区(drop partition)

Alter table xxx drop partition ppp;

删除子分区:

Alter table xxx drop subpartition ppp;

此功能hash不支持。同时要注意,删除分区会同时删除该分区内数据。

同样,如果不指定update indexes的话该操作会导致GLOBAL索引失效,而LOCAL不会,因为对应的LOCAL索引分区也被删除了嘛,其他分区的LOCAL不会受到影响。

4. 交换分区(exchange partition)

Alter table tb1 exchange partition/subpartition p1 with table tb2;

据说是采用了更改数据字典的方式,所以速度比较快。

可以是分区跟非分区表交换,子分区跟非分区表交换,组合分区跟分区表交换。

例如:

组合分区跟分区表交换:

CREATE TABLE t1 (i NUMBER, j NUMBER)

     PARTITION BY HASH(i)

       (PARTITION p1, PARTITION p2);

CREATE TABLE t2 (i NUMBER, j NUMBER)

     PARTITION BY RANGE(j)

     SUBPARTITION BY HASH(i)

        (PARTITION p1 VALUES LESS THAN (10)

            SUBPARTITION t2_pls1

            SUBPARTITION t2_pls2,

         PARTITION p2 VALUES LESS THAN (20)

            SUBPARTITION t2_p2s1

            SUBPARTITION t2_p2s2));

ALTER TABLE t2 EXCHANGE PARTITION p1 WITH TABLE t1

     WITH VALIDATION;

如果指定WITH VALIDATION(默认) 会对交换进来的数据进行合法检查,看是否符合该分区的规则,WITHOUT VALIDATION 会忽略合法检查(比如ID=12的记录此时可以交换到ID VALUES LESS THAN (10)的分区里),但如果表上有primary key 或unique 约束的话,指定without validation会被忽略。

同样,如果不指定UPDATE INDEXES ,GLOBAL 索引会失效,需要重新编译。

5. 合并分区(merge partitions)

Alter table xxx merge partitions/subpartitions p1,p2 into partiton/subpartition p3 [TABLESPACE tablespace_name];

HASH不适用,因为它有COALESCE了嘛。

表分区必须是相邻的。

跟COALESCE一样,会产生IO,数据量大的话,IO也是相当大的。

同样可以用UPDATE INDEXES 避免索引失效

6. 修改LIST分区—ADD VALUES

Alter table xxx modify partition/subpartition p1 add values(7,9);

要注意的是,增加的VALUES不能在其他分区列的VALUES值中存在,也不能在DEFAULT分区(如果有的话)中有相应VALUES.

不会影响索引

7. 修改LIST 分区—DROP VALUES

Alter table xxx modify partition/subpartition p1 drop values(8,9);

同样,删除的values 不能存在记录.

不会影响索引

8. 拆分分区(split partitions)

功能与MERGE PARTITIONS相反。通常我们会用来拆分MAXVALUE/DEFAULT分区。

Range partition:

Alter table xxx split partition/subpartition p1 at (15) into (partition/subpartition
p1_new1,partition/subpartition p1_new2);

List partition:

Alter table xxx split partition/subpartition p1 values(15,16) into (partition/subpartition p1_new1,partition/subpartition p1_new2);

原分区中符合新值定义的记录会存入第一个分区,其他存入第二个分区,当然,在新分区后面可以指定属性,比如TABLESPACE。

HASH分区不适用。

会产生IO

同样,可用update indexes 来避免索引失效

9. 截断分区(truncate partition)

跟TRUNCATE TABLE一样,截断该分区内的数据。

Alter table xxx truncate partition/subpartition p1;

同样,可用update indexes 来避免索引失效

10. 移动分区(move partition)

Alter table xxx move partition/subpartition p1 …;

有些功能比如改变分区表空间,modify partition就做不到,此时就可以用move partition来做。

Use the MOVE PARTITION clause of the ALTER TABLE statement to:

• Re-cluster data and reduce fragmentation

• Move a partition to another tablespace

• Modify create-time attributes

• Store the data in compressed format using table compression

如:

ALTER TABLE parts MOVE PARTITION depot2

     TABLESPACE ts094 NOLOGGING COMPRESS;

(如果指定compress,affects only future storage, but not existing data.)

同样,可用update indexes 来避免索引失效

11. 重命名分区(rename partition)

Alter table xxx rename partition/subpartition p1 to p1_new;

跟重命名表差不多。

12. 修改分区默认属性(modify default attributes)

修改表属性:alter table xxx modify default attributes …

修改分区属性(适用于组合分区):alter table xxx modify default attributes for partition p1 …

只对以后添加的分区产生影响,适用于所有分区,其中hash分区只能修改表空间属性。

如:

Alter table xxx modify default attributes tablespace users;

13. 修改子分区模板属性(set subpartition template)

Alter table xxx set subpartition template (…);

仅影响以后的子分区,当前的子分区属性不会改变

如:

Alter table xxx set subpartition template

(partition p1 tablespace tbs_1,

Partition p2 tablespace tbs_2);

如果要取消掉子分区模板:

Alter table xxx set subpartition template ();

Oracle分区表管理的一些笔记的更多相关文章

  1. Oracle 分区表管理之组合分区(分区索引失效与性能比较)

    整体结构如下: Oracle  分区表管理之组合分区(分区索引失效与性能比较) 虽然老早就使用了分区表,终于有时间写有关分区表的内容:不是所有的场景数据量变大需要用到分区表,一般单表数据超过2g可以考 ...

  2. oracle 分区表(子分区)收缩笔记

    思路1.首先移动子分区到别的表空间.2.收缩数据文件.3.再把子分区移回原表空间. ---------------------------------------------生成发送报告移动子分区语句 ...

  3. 【三思笔记】 全面学习Oracle分区表及分区索引

    [三思笔记]全面学习Oracle分区表及分区索引 2008-04-15 关于分区表和分区索引(About PartitionedTables and Indexes) 对于 10gR2 而言,基本上可 ...

  4. 谈一下如何设计Oracle 分区表

    在谈设计Oracle分区表之间先区分一下分区表和表空间的个概念: 表空间:表空间是一个或多个数据文件的集合,所有数据对象都存放在指定的表空间中,但主要存放表,故称表空间. 分区表:分区致力于解决支持极 ...

  5. Oracle内存管理技术

    1.Oracle内存管理技术 2.配置自动内存管理(AMM) 3.监视自动内存管理(AMM) 4.配置自动共享内存管理(ASMM) 5.配置自动PGA内存管理 Reference 1.Oracle内存 ...

  6. 深入学习Oracle分区表及分区索引

    关于分区表和分区索引(About Partitioned Tables and Indexes)对于10gR2而言,基本上可以分成几类: •       Range(范围)分区 •       Has ...

  7. oracle 分区表和分区索引

    很复杂的样子,自己都没有看完,以备后用 http://hi.baidu.com/jsshm/item/cbfed8491d3863ee1e19bc3e ORACLE分区表.分区索引ORACLE对于分区 ...

  8. 谈一下怎样设计Oracle 分区表

    在谈设计Oracle分区表之间先区分一下分区表和表空间的个概念: 表空间:表空间是一个或多个数据文件的集合,全部数据对象都存放在指定的表空间中,但主要存放表,故称表空间. 分区表:分区致力于解决支持极 ...

  9. Oracle DBA管理包脚本系列(二)

    该系列脚本结合日常工作,方便DBA做数据管理.迁移.同步等功能,以下为该系列的脚本,按照功能划分不同的包.功能有如下: 1)数据库对象管理(添加.修改.删除.禁用/启用.编译.去重复.闪回.文件读写. ...

随机推荐

  1. 498B Name That Tune

    传送门 题目大意 n首音乐,第i首被听出来的概率为pi,刚开始听第一首,1s后如果听出来了则放第下一首,否则接着听这一首,第i首在连续听了ti s之后一定会被听出来,问Ts后听出来的歌的期望数量. 分 ...

  2. laravel的mvc

  3. nodelet的理解

    1.介绍 nodelet包可以为在相同进程中的多个算法之间实现零拷贝的传输方式. 这个包也提供了实现一个nodelet所需的nodelet基类以及用于实例化nodelet的NodeletLoader类 ...

  4. Python基础-4

    目录 迭代器&生成器 装饰器 Json & pickle 数据序列化 软件目录结构规范 1.列表生成式,迭代器&生成器 看列表[0, 1, 2, 3, 4, 5, 6, 7, ...

  5. PS插件开发plugin

    Photoshop插件开发 VC++制作Photoshop自动化插件:http://blog.sina.com.cn/s/blog_73c52fda0101c7hw.html Photoshop 的扩 ...

  6. vmware ubuntu安装vmware tools

    vmware tools可以说是其平台虚拟机必不可少的工具,可以使母机(你的电脑)通过复制粘贴向虚拟机中传递文件信息,对我们虚拟机的使用由非常大的帮助,当然也可以通过使用共享硬盘来共享文件,但操作起来 ...

  7. SharePoint配置网站集的审核设置

    配置网站集的审核设置 您可以使用 Microsoft SharePoint Server 2010 的审核功能来跟踪哪些用户对网站集的网站.内容类型.列表.库.列表项和库文件执行了哪些操作.了解谁对哪 ...

  8. 使用JS完成首页定时弹出广告图片

    一.需求分析 在首页中的顶部做一个定时弹出广告图片. 二.技术分析 隐藏图片: display: none        定时操作: setInterval(“显示图片的函数”, 3000); 三.代 ...

  9. 不同数据库表结构的转化,PowerDesigner的使用教程

    通过学习PowerDesigner工具,学习概念模型,物理模型,面向对象模型,业务模型,以及不同数据库表结构的转化. 通过案例给大家分享,sql server 2008r2 数据库和oracle数据库 ...

  10. NetCore服务虚拟化01(集群组件Sodao.Core.Grpc)

    一. 起始 去年.NetCore2.0的发布,公司决定新项目采用.NetCore开发,当作试验.但是问题在于当前公司内部使用的RPC服务为Thrift v0.9 + zookeeper版本,经过个性化 ...