返回顶部
首页 > 资讯 > 数据库 >Greenplum -- 最全分区表操作
  • 346
分享到

Greenplum -- 最全分区表操作

2024-04-02 19:04:59 346人浏览 八月长安
摘要

一、Greenplum 分区原理 分区表意思是将一个大表在物理上分割成几块,GPDB中的分区表和postgresql中实现原理一样,都是用过表继承、约束来实现。但是与Postgresql也有所不同,在Pos

一、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; 
您可能感兴趣的文档:

--结束END--

本文标题: Greenplum -- 最全分区表操作

本文链接: https://lsjlt.com/news/45990.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Greenplum -- 最全分区表操作
    一、Greenplum 分区原理 分区表意思是将一个大表在物理上分割成几块,GPDB中的分区表和PostgreSQL中实现原理一样,都是用过表继承、约束来实现。但是与PostgreSQL也有所不同,在Pos...
    99+
    2024-04-02
  • Oracle分区表的move操作
    关于分区表的move操作还是很值得深究的一个问题。如果分区表中含有lob字段,难度还会加大。对于普通的表而言,做move操作室理所当然,oracle提供的方式很直接快捷。当然了这个命令也不是高可用的范畴。但...
    99+
    2024-04-02
  • Mysql表分区的操作方法
    这篇文章主要讲解了“Mysql表分区的操作方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql表分区的操作方法”吧! M...
    99+
    2024-04-02
  • MySQL分区表和分桶表的操作详解
    目录1.创建分区表2.增删改查操作2.1 插入数据2.2 操作数据3. 二级分区表3.1 创建分区表3.2 插入数据4.动态分区5.分桶表5.1 新建分桶表5.2 插入数据5.3 既分区有分桶6 分区与分桶的区别1.创建...
    99+
    2023-05-12
    MySQL分区表和分桶表 MySQL分区表 MySQL分桶表
  • oracle表分区的概念及操作
    oracle表分区详解 1.表空间及分区表的概念 表空间:   是一个或多个数据文件的集合,所有的数据对象都存放在指定的表空间中,但主要存放的是表, 所以称作表空间。 分区表: 当表...
    99+
    2024-04-02
  • Navicat for MySQL进行表分区操作(图解)
    1.建表  要创建表分区,分区的条件(采用timestamp类型)要被设置为主键(必须),或者整个表都没有主键(可以在分区完毕之后再补上) 或者 2.切换到分区操作界面 3.进行分区操作...
    99+
    2024-04-02
  • PostgreSQL12.5中分区表的一些操作实例
    目录1、创建一个有DEFAULT的分区表1、先创建主表2、如果没有创建分区就直接插入数据会报错3、创建分区4、查看分区情况2、有default 分区,再加分区解决办法:3、没有default的分区4、给分区表ddl4.1...
    99+
    2022-08-12
    pg查看分区表 pg 分区 pg创建分区表
  • 如何进行分区表split操作及maxvalue处理
    这篇文章将为大家详细讲解有关如何进行分区表split操作及maxvalue处理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。CREATE TABLE DFMS.WIP_D_WO_DETAIL...
    99+
    2023-06-06
  • Java Stream 最全操作用法合集
    Java 8 引入了Stream流的操作,让我们在开发的过程中感受到了很多的便利,小宋我也花时间总结了下关于Stream的堪称最全的使用方法,话不多说,直接放大招。 流(stream)的类型 Java 8提供了两种方式去创建流: 1、str...
    99+
    2023-08-22
    java jvm 开发语言
  • linq中的分区操作符
    Linq中的分区指的是在不重新排列元素的情况下,将输入序列划分为两部分,然后返回其中一个部分的操作。 一、Take操作符 Take(int n)表示将从序列的开头返回数量为n的连续元...
    99+
    2024-04-02
  • mysql数据表的基本操作之表结构操作,字段操作实例分析
    本文实例讲述了mysql数据表的基本操作之表结构操作,字段操作。分享给大家供大家参考,具体如下: 本节介绍: 表结构操作 创建数据表、 查看数据表和查看字段、 修改数据表结构 删除数据表 字段操作...
    99+
    2022-05-11
    mysql 数据表 表结构 字段
  • win10怎么分区?win10硬盘分区的操作教程
    很多朋友在进行win10分区的时候可能总是考虑到害怕系统盘空间太小会影响电脑读写速度。但是所造成的后果却是由于win10分区C盘太大,而其他分区的储存容量变得十分紧张。储存不够用,电脑光是运作快,这样也失去了计算机原来的...
    99+
    2023-06-11
    win10分区 硬盘分区 win10 教程 操作
  • oracle 12c分区表不完全索引分析
    本篇内容主要讲解“oracle 12c分区表不完全索引分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“oracle 12c分区表不完全索引分析”吧!实验一实验...
    99+
    2024-04-02
  • oracle分区表的常规操作导致对索引的影响
    oracle分区表的常规操作导致对索引的影响      oracle分区表目前已经很普遍的应用于我们的生产系统,但是在日常需要维护分区表的时候,一些对于分...
    99+
    2024-04-02
  • C++序列操作函数学习最全指南
    目录前言A.查找算法简单查找查找重复值查找子序列B.其他只读算法C.二分查找算法D.只写算法E.划分和排序划分排序F.重排算法G.排列H.集合算法I.杂项总结前言 标准库定义了许多用...
    99+
    2024-04-02
  • pyspark操作hive分区表及.gz.parquet和part-00000文件压缩问题
    目录pyspark 操作hive表1> saveAsTable写入2> insertInto写入2.1> 问题说明2.2> 解决办法3>saveAsTe...
    99+
    2024-04-02
  • Oracle分区表全局索引添加分区时不会失效
    COALESCE PARTITION | SUBPARTITION (hash) DROP PARTITION | SUBPARTITION EXCHANGE PARTITION | SUBPART...
    99+
    2024-04-02
  • oracle分区表的作用是什么
    oracle分区表的作用是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。  1.表空间及分区表的概念  表空间:是一个或多个数据文件的集合...
    99+
    2024-04-02
  • sqlserver表分区的作用是什么
    SQL Server表分区的作用包括以下几点: 提高性能:表分区可以将数据分散存储在不同的物理存储介质上,从而提高查询性能和数据...
    99+
    2024-04-20
    sqlserver
  • MySQL创建表操作命令分享
    目录一、表命令1.查看所有表2.创建表3.创建一个用户表二、MySQL支持的常用数据类型1.数字型2.字符串3.日期三、MySQL支持的常用约束四、存储引擎五、表命令(crud)1....
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作