Greenplum分区表操作汇总(greenplum partition)
mhr18 2024-10-20 06:42 20 浏览 0 评论
1.Greenplum分区表简介
在数据库中,分区表,有时候我们也叫分库分表,底层的逻辑基本都是一样的,就是将一个大表在物理上分布在不同数据库上,数据也拆分开,方便查询时进行分区裁剪以减少查询数据量。GPDB中的分区表功能在开发时,参考了Oracle的分区表语法,在GPDB中,可以直接向父表插入数据,也可以直接向子表插入数据,当直接向父表插入数据时,GPDB会自动检测并将数据定位到子表中。
2.如何创建分区表
GPDB中,支持两种分区表,范围分区(range)和列表分区(list),下面展开介绍一下具体的创建语法。
2.1 范围分区(range)
根据分区字段的值范围区间来分区,每一个分区就是一个子表
create table t_partition_range
(
id int,
name varchar(64),
fdate varchar(64)
) distributed by (id)
partition by range(fdate)
(
partition p1 start ('2022-01-01') inclusive end ('2022-02-01') exclusive,
partition p2 start ('2022-02-01') inclusive end ('2022-03-01') exclusive,
default partition default_p
);
注意上面分区表我定义的日期,前后是有衔接关系的,如果不衔接起来,可能发生缺少分区的情况:
inclusive :指定包含,例如上面的 start ('2022-01-01') inclusive 则是包含'2022-01-01'
exclusive : 指定不包含, 例如上面的 end ('2022-02-01') exclusive 则是不包含'2022-02-01'
2.2 快速范围分区(every)
根据选定的范围,跨越基数,快速分区每一个子表
create table t_partition_every_1
(
id int,
name varchar(64),
fdate date
)
distributed by (id)
partition by range (fdate)
(
partition pn_ start ('2022-01-01'::date) end ('2022-12-31'::date) every ('1 day'::interval),
default partition default_p
);
every:指定跨越基数
2.3 列表分区(list)
根据值得分组,相同的数据归类到一组,也就一个分区中
create table t_partition_list
(
id int,
name varchar(64),
fdate varchar(10)
)
distributed by (id)
partition by list (fdate)
(
partition p1 values ('2022-01-01', '2017-01-02'),
partition p2 values ('2022-01-03'),
default partition default_p
);
3.分区相关操作
3.1 分区拆分
拆分普通分区:
将分区p2在 '2022-02-20' 左右切分成两块
alter table t_partition_range split partition p2 at ('2022-02-20') into (partition p2, partition p3);
切割默认分区:
alter table t_partition_range split default partition start ('2022-03-01') end ('2022-03-31') into (partition p4, default partition);
3.2 新增分区
如果存在默认分区(default partition),则不能新增(add)分区,只能拆分默认分区(split default partition)
alter table t_partition_range_1 add partition p2 start ('2022-02-01') end ('2022-02-31');
3.3 删除分区
alter table t_partition_range_1 DROP partition p2;
3.4 清空分区数据
清空分区表数据,相当于删除分区,然后再新建一个
alter table t_partition_range_1 truncate partition p1;
或根据rank号去删除对应分区,如下:
alter table sales truncate partition for(rank(1));
4.子分区创建与操作
4.1 子分区创建
在GPDB中,分区是可以嵌套增加的,分区下面可以有子分区,如下:
create table t_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 ('abcd'),
subpartition c2 values ('efgh')
)
(
partition p1 start ('2022-01-01') end ('2022-01-31')
);
上面的分区中,p1会再分两个c1/c2子分区
4.2 truncate 子分区
alter table t_partition_range_2 alter partition p1 truncate partition c2;
4.3 drop 子分区
alter table t_partition_range_2 alter partition p1 drop partition c2;
相关推荐
- Spring 事务 @Transactional注解 面试及原理
-
1.你在项目中是如何使用事物的?我们项目的框架都是使用的Spring,spring分为编程式事务,在代码中硬编码。声明式事务,在配置文件中配置(推荐使用)声明式事务又分为两种:基于XML的声明式事...
- MySQL事务详解(mysql的事务)
-
目录一、MySQL事务的定义二、事务的ACID特点1.原子性2.一致性3.隔离性4.持久性5.数据不一致产生的结果(1)脏读(读取未提交数据)(2)不可重复读(前后多次读取,数据内容不一致)(3)幻读...
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
-
一、JobRepository是谁?——批处理的“档案馆”JobRepository是SpringBatch的“记忆中枢”,负责记录所有Job和Step的执行状态。它像一位严谨的档案管理员,把任务执...
- Java面试题之Spring事物(java spring 事务)
-
1.事务的7种传播级别①REQUIRED,默认的spring事务传播级别,使用该级别的特点是,如果上下文中已经存在事务,那么就加入到事务中执行,如果当前上下文中不存在事务,则新建事务执行。所以这个...
- Spring框架基础知识-第三节内容(spring框架总结)
-
Spring支持的事务管理类型Spring支持两种类型的事务管理。1、编程式事务管理在此过程中,在编程的帮助下管理事务。它为您提供极大的灵活性,但维护起来非常困难。2、声明式事务管理事务管理与业务代码...
- 「一文搞懂」MySQL事务实现原理(mysql事务处理机制)
-
本章内容事务定义事务指的是保证一组数据库操作,要么全部成功,要么全部失败。在MySQL中,事务支持是在引擎层实现的,MySQL是一个支持多引擎的系统,但并不是所有的引擎都支持事务。如:MySQL原生的...
- PostgreSQL中json实现中的最大亮点:索引的“模式自由”
-
1.索引的模式自由介绍我们知道在文档型数据库中最大的亮点是使用json实现了模式自由。模式自由也称为无模式,模式自由的最大好处就是不需要事先确定表结构就可以灵活的存储各种结构的数据,对开发人员来说就...
- 【SQL】SQL 语法差异大全(PgSQL/MySQL/Oracle/TiDB/OceanBase)
-
以下是针对不同数据库系统的SQL语法差异总结,按功能分类展示:一、基础查询1.分页查询--PostgreSQL/TiDB/OceanBaseSELECT*FROMTableNameL...
- 【预警通报】关于WebLogic存在远程代码执行高危漏洞的预警通报
-
近日,Oracle官方发布了2021年1月关键补丁更新公告CPU(CriticalPatchUpdate),共修复了包括CVE-2021-2109(WeblogicServer远程代码执行漏洞)...
- 医院信息系统突发应急演练记录(医院信息化应急演练)
-
信息系统突发事件应急预案演练记录演练内容信息系统突发事件应急预案演练参与人员信息科参与科室:全院各部门日期xxxx-xx-xx时间20:00至24:00地点信息科记录:xxx1、...
- 一文掌握怎么利用Shell+Python实现完美版的多数据源备份程序
-
简介:在当今数字化时代,无论是企业还是个人,数据的安全性和业务的连续性都是至关重要的。数据一旦丢失,可能会造成无法估量的损失。因此,如何有效地对分布在不同位置的数据进行备份,尤其是异地备份,成为了一个...
- docker搭建系统环境(docker搭建centos)
-
Docker安装(CentOS7)1.卸载旧版Docker#检查已安装版本yumlistinstalled|grepdocker#卸载旧版本yumremove-ydocker.x...
- 基础篇:数据库 SQL 入门教程(sql数据库入门书籍推荐)
-
SQL介绍什么是SQLSQL指结构化查询语言,是用于访问和处理数据库的标准的计算机语言。它使我们有能力访问数据库,可与多种数据库程序协同工作,如MSAccess、DB2、Informix、M...
- Java21杀手级新特性!3行代码性能翻倍
-
导语某券商系统用这招,交易延迟从12ms降到0.8ms!本文揭秘Oracle官方未公开的Record模式匹配+虚拟线程深度优化+向量API神操作,代码量直降70%!一、Record模式匹配(代码量↓8...
- 一文读懂JDK21的虚拟线程(java虚拟线程)
-
概述JDK21已于2023年9月19日发布,作为Oracle标准Java实现的一个LTS版本发布,发布了15想新特性,其中虚拟线程呼声较高。虚拟线程是JDK21中引入的一项重要特性,它是一种轻量级的...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Spring 事务 @Transactional注解 面试及原理
- MySQL事务详解(mysql的事务)
- Spring Batch中的JobRepository:批处理的“记忆大师”是如何工作
- Java面试题之Spring事物(java spring 事务)
- Spring框架基础知识-第三节内容(spring框架总结)
- 「一文搞懂」MySQL事务实现原理(mysql事务处理机制)
- PostgreSQL中json实现中的最大亮点:索引的“模式自由”
- 【SQL】SQL 语法差异大全(PgSQL/MySQL/Oracle/TiDB/OceanBase)
- 【预警通报】关于WebLogic存在远程代码执行高危漏洞的预警通报
- 医院信息系统突发应急演练记录(医院信息化应急演练)
- 标签列表
-
- oracle位图索引 (74)
- oracle基目录 (50)
- oracle批量插入数据 (65)
- oracle事务隔离级别 (59)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)