Greenplum -- 最全分区表操作
admin
2023-05-09 15:42:03
0

一、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; 

相关内容

热门资讯

燃气热水器需要多少升的 一般在选择燃气热水器的时候,按照家庭内部的使用水的人数来决定,一般如果四个人的话,可以选择40到60...
32升燃气热水器安装方法 燃气热水器是现代家庭生活中非常重要的设备,它不仅方便了我们的生活,提高了生活品质,同时也需要我们重视...
燃气热水器12升和13升的区别... 燃气热水器12升和13升的区别大吗:区别不大。12升就是热水器的额定加热能力是每分钟可以提升水温25...
燃气热水器温度升不上去的原因是... 1、燃气的压力不够大,导致水温无法升高。2、热水器内部的电池电量已经不够运转热水器。3、没有做好卫生...
海尔滚筒洗衣机衣服放进后门锁不... 卡锁松懈或老化故障可以找专业的售后将卡锁部分卸下换一个新的就可以正常使用。可以适当的拿出些许衣服以释...
小米、特斯拉、比亚迪相继调价 ...   小米、特斯拉、比亚迪相继调价  【小米、特斯拉、比亚迪相继调价】2026年5月,中国新能源车市上...
雨雨雨雨雨雨!14日至19日河... 晴雨转换!今天起河南雨雨雨雨雨雨本周河南天气呈现先晴后雨的特点,在经历了前半段晴热模式之后,今天我省...
进出口总量全省第6、鲜苹果出口... 2026年一季度,三门峡市外贸经济稳健向好,交出一份亮眼成绩单:全市实现进出口总值57.9亿元,同比...
法国外交部回应特朗普访华 据凤凰卫视报道,美国总统特朗普访问中国,中美关系走向引发欧洲关注。法国外交部发言人5月13日在巴黎接...
特朗普社媒实际发帖人现身:34... 现年34岁的行政助理娜塔莉·哈普是美国总统特朗普的“资深心腹”,目前已成为协助特朗普在社交平台“真实...