博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Greenplum -- 最全分区表操作
阅读量:6818 次
发布时间:2019-06-26

本文共 2667 字,大约阅读时间需要 8 分钟。

一、Greenplum 分区原理

分区表意思是将一个大表在物理上分割成几块,GPDB中的分区表和PostgreSQL中实现原理一样,都是用过表继承、约束来实现。但是与PostgreSQL也有所不同,在PostgreSQL中,一个父表,多个子表来实现分区表,需要手动向子表插入数据,如果向父表插入数据,则直接会被插入到父表中,在GPDB中,可以直接想父表插入数据,便可以根据约束直接自动向对应的子表插入数据,当分区子表不存在时,插入失败

 

二、分区表创建

2.1、范围分区(range)

根据分区字段的值范围区间来分区,每一个分区就是一个子表

eg:create table test_partition_range(    id int,     name varchar(64),     fdate varchar(64)    ) distributed by (id)     partition by range(fdate)     (        partition p1 start ('2017-01-01') inclusive end ('2017-01-31') exclusive,         partition p2 start ('2017-02-01') inclusive end ('2017-02-29') exclusive,         default partition default_p    );    inclusive :指定包含,例如上面的 start ('2017-01-01') inclusive 则是包含'2017-01-01'    exclusive : 指定不包含, 例如上面的 end ('2017-01-31') exclusive 则是不包含'2017-01-31'

 

2.2、快速分区(every)

根据选定的范围,跨越基数,快速分区每一个子表

eg:create table test_partition_every_1 (    id int,     name varchar(64),     fdate date) distributed by (id) partition by range (fdate) (    partition pn_ start ('2017-01-01'::date) end ('2017-12-31'::date) every ('1 day'::interval),     default partition default_p);every:指定跨越基数

 

2.3、list分区(list)

根据值的分组,相同的数据归类到一组,也就一个分区中

eg:create table test_partition_list (    id int,     name varchar(64),     fdate varchar(10)) distributed by (id) partition by list (fdate) (    partition p1 values ('2017-01-01', '2017-01-02'),     partition p2 values ('2017-01-03'),     default partition pd);

 

三、分区相关操作

3.1、分区split

切割普通分区:

将分区p2 在 '2017-02-20' 左右切分成两块 alter table test_partition_range split partition p2 at ('2017-02-20') into (partition p2, partition p3); 切割默认分区:alter table test_partition_range split default partition start ('2017-03-01')  end ('2017-03-31')  into (partition p4, default partition);

 

3.2、分区add

如果存在default partition,则不能add分区,只能split default partition

alter table test_partition_range_1 add partition p2 start ('2017-02-01') end ('2017-02-31');

 

3.3、分区drop

彻底删除对应的分区表

alter table test_partition_range_1 DROP partition p2;

 

3.4、分区truncate

清空分区表数据,相当于删除分区,然后再新建一个

alter table test_partition_range_1 truncate partition p1;

 

四、子分区创建与操作

4.1、子分区创建

在GPDB中,分区是可以嵌套增加的,分区下面可以有子分区

create table test_partition_range_2 (    id int,     name varchar(64),     fdate varchar(10)) distributed by (id) partition by range(fdate) subpartition by list(name) subpartition template(    subpartition c1 values ('xiaoxiao'),     subpartition c2 values ('xiaohua'))(    partition p1 start ('2017-01-01') end ('2017-01-31'))上面的分区中,p1会再分两个c1/c2子分区

 

4.2、truncate 子分区

alter table test_partition_range_2 alter partition p1 truncate partition c2;

 

4.3、drop 子分区

alter table test_partition_range_2 alter partition p1 drop partition c2;

转载于:https://blog.51cto.com/13126942/2053712

你可能感兴趣的文章
杭电3635--Dragon Balls(并查集)
查看>>
npm install报错Unhandled rejection RangeError: Maximum call stack size exceededill install
查看>>
使用MSMQ 远程队列
查看>>
理解OAuth 2.0
查看>>
Out Ref用法
查看>>
得到颜色的整形值
查看>>
.net winForm 实现类似qq 弹出新闻
查看>>
SSL加速和证书卸载的配置方式
查看>>
Intersect交集
查看>>
Sencha touch 中的一段源码匿名中定义Function并调用
查看>>
android开发学习 ------- 枚举类型在Android中的用法
查看>>
day14 装饰器模拟验证附加功能
查看>>
c#简单自定义异常处理日志辅助类
查看>>
make: *** No targets specified and no makefile found. Stop.错误
查看>>
闭包的常见用处
查看>>
中联通4月份3G用户净增181.7万总数突破2000万
查看>>
cJSON填坑记
查看>>
css3(border-radius)边框圆角详解(转)
查看>>
Python MySQLdb 使用utf-8 编码插入中文数据
查看>>
hdu1406
查看>>