PostgreSQL PARTITION 分区表

PostgreSQL 分区表,操作性相当便捷。

但只能在创建时决定是否为分区表,并决定分区条件字段,普通表创建后,不能在修改为分区表。

Note:通过其他方法也可转化为分区表。

和其他数据库一样,分区表作为一个DB的特性,优点自不用说,物理分散,逻辑统一。

必须要注意的一个缺点是:分区表不允许其他表作为外键引用。只能在真实场景业务逻辑上当作外键,设计时论场景再推敲。

同时,在Pg 11以前只能单独为每个分区表建立索引等,且不能在【母表】上建立主键、索引等。

Pg 11以后可以针对“逻辑”分区表(母表)建立索引,分区子表自动创建。

简单Sql:

 1 --DROP TABLE dbo.table01;
 2
 3 CREATE TABLE dbo.table01 (
 4   id        bigserial NOT NULL,
 5   cre_time  timestamp without time zone,
 6   note      varchar(30)
 7 ) PARTITION BY RANGE (cre_time)
 8   WITH (
 9     OIDS = FALSE
10   );
11
12 CREATE TABLE dbo.table01_2018
13   PARTITION OF dbo.table01
14   FOR VALUES FROM (‘2018-01-01 00:00:00‘) TO (‘2019-01-01 00:00:00‘);
15
16 CREATE TABLE dbo.table01_2017
17   PARTITION OF dbo.table01
18   FOR VALUES FROM (‘2017-01-01 00:00:00‘) TO (‘2018-01-01 00:00:00‘);
19
20 ALTER TABLE dbo.table01
21   OWNER TO postgres;

原文地址:https://www.cnblogs.com/jonney-wang/p/9238923.html

时间: 2024-10-12 09:29:36

PostgreSQL PARTITION 分区表的相关文章

【PostgreSQL】分区表

PostgreSQL中的分区表是通过表继承来实现的(表继承博客http://www.cnblogs.com/NextAction/p/7366607.html).创建分区表的步骤如下: (1)创建“父表”,所有的分区表都从这张表继承.“父表”中不存数据,也不要定义约束和索引. (2)创建“子表”,所有“子表”都是从“父表”中继承而来.这些“子表”就是所谓的分区,其实它们也是PostgreSQL表. (3)给分区表创建约束. (4)在分区表上创建索引. (5)创建触发器,把对“父表”的插入重定向到

PostgreSQL 创建分区表(转 仅供自己参考)

典型使用场景 随着使用时间的增加,数据库中的数据量也不断增加,因此数据库查询越来越慢. 加速数据库的方法很多,如添加特定的索引,将日志目录换到单独的磁盘分区,调整数据库引擎的参数等.这些方法都能将数据库的查询性能提高到一定程度. 对于许多应用数据库来说,许多数据是历史数据并且随着时间的推移它们的重要性逐渐降低.如果能找到一个办法将这些可能不太重要的数据隐藏,数据库查询速度将会大幅提高.可以通过DELETE来达到此目的,但同时这些数据就永远不可用了. 因此,需要一个高效的把历史数据从当前查询中隐藏

PostgreSql Partition + Hibernate Insert

与Oracle不同.PostgreSQL须要手动控制分区规则触发器. 步骤一:创建分区 CREATE TABLE table_partition_1( CHECK partition_column criteria) INHENRITS (table) 步骤二:为分区表创建PK跟index,这里使用btree ALTER TABLE ONLY table_partition_1 ADD CONSTRAINT table_partition_1_pkey PRIMARY KEY (key_colu

Postgresql 添加分区表(按月和按日通用)

建了分区表的同学相信添加分区表很头疼,如果有按月分区又有按日分区的,而且是通过"_yyyymmdd"或者"_yyyymm"后缀进行分区的,那么可以用这个函数进行添加分区 CREATE OR REPLACE FUNCTION f_add_partition() RETURNS void LANGUAGE plpgsql AS $function$ declare v_max_childname text;  --最大子表名称 v_parentname text;  -

详解Oracle partition分区表

随着表中行数的增多,管理和性能性能影响也将随之增加.备份将要花费更多时间,恢复也将 要花费更说的时间,对整个数据表的查询也将花费更多时间.通过把一个表中的行分为几个部分,可以减少大型表的管理和性能问题,以这种方式划分发表数据的方法称为对表的分区.分区表的优势: (1)改善查询性能:对分区对象的查询可以仅搜索自己关心的分区,提高检索速度: (2)方便数据管理:因为分区表的数据存储在多个部分中,所以按分区加载和删除数据比在大表中加载和删除数据更容易: (3)方便备份恢复:因为分区比被分区的表要小,所

PostgreSQL之分区表(partitioning)

PostgreSQL有一项非常有用的功能,分区表,或者partitioning.当某个TABLE的记录非常的多,千万甚至更多的时候,我们其实需要将他分割成子表.一个庞大的TABLE,就像水果仓库杂乱无章地堆放着无数的苹果桃子和桔子,查找不方便,性能降低,比较合理的做法是将仓库分成三个子区域,分表放苹果桃子和桔子.一张大表就变成了三个小表的集合. 通过合理的设计,可以将选择一定的规则,将大表切分多个不重不漏的子表,这就是传说中的partitioning.比如,我们可以按时间切分,每天一张子表,比如

PostgreSQL的分区表建立

在数据库日渐庞大的时候,为了方便对数据库数据的管理,比如按时间,按地区去统计一些数据时,基数过于庞大,多有不便.很多商业数据库都提供分区的概念,按不同的维度去存放数据,便于后期的管理,PG也不例外.下面是分区表创建步骤: 1.建立主表 create table parent_table( id int, name character varying(20), create_time timestamp without time zone); 2.建立子表,继承于主表 create table p

MySQL 分区表原理及数据备份转移实战

1.分区表含义 分区表定义指根据可以设置为任意大小的规则,跨文件系统分配单个表的多个部分.实际上,表的不同部分在不同的位置被存储为单独的表.用户所选择的.实现数据分割的规则被称为分区函数,这在MySQL中它可以是模数,或者是简单的匹配一个连续的数值区间或数值列表,或者是一个内部HASH函数,或一个线性HASH函数. 分表与分区的区别在于:分区从逻辑上来讲只有一张表,而分表则是将一张表分解成多张表. 2.分区表优点 1)分区表更容易维护.对于那些已经失去保存意义的数据,通常可以通过删除与那些数据有

Hive管理表分区的创建,数据导入,分区的删除操作

Hive分区和传统数据库的分区的异同: 分区技术是处理大型数据集经常用到的方法.在Oracle中,分区表中的每个分区是一个独立的segment段对象,有多少个分区,就存在多少个相应的数据库对象.而在Postgresql中分区表其实相当于分别建立了很多小表,其实和Oracle是异曲同工罢了. 在HIVE中的管理表其实就是在数据库目录下的一个和表名称一样的目录,数据文件都存放在该目录下,如果在Hive中查询一张表数据,那就需要遍历该目录下的所有数据文件,如果表的数据非常庞大,那查询性能会很不好. 管