postgresql 分区表 创建函数

该博客介绍了一个用于创建PostgreSQL分区表的Python函数,支持按天或月进行分区,并提供了创建继承表、索引、错误表及触发器的逻辑。函数参数包括表名、开始日期、结束日期、分区类型和分区字段,通过PL/Pythonu语言执行。
摘要由CSDN通过智能技术生成
postgresql中,并没有分区表的创建命令,是通过创建继承表及约束等规则来创建,步骤繁琐且麻烦,邮件中封装了一个方法。便于创建分区表

规范:

postgresql中 时间分区字段请统一采用  timestamp(0) 类型

一、原始表 tbl_partition

create table tbl_partition (
id integer,
name varchar(20),
gender boolean,
yyyymmdd timestamp(0),
dept char(4)
);


二、将普通表转换为分区表(public.partition_generate)

select public.partition_generate('public.tbl_partition','20130101','20130103','day','yyyymmdd');

参数说明:
  1. 表名 schema.tablename 格式
  2. 创建分区的起始时间
  3. 创建分区的结束时间
  4. 分区类型 day:天分区  mon:月分区
  5. 分区字段

三、创建结果(其中一个是错误表,用于存放不能映射的分区)


四、验证数据






五、源码




CREATE or REPLACE FUNCTION public.partition_generate(tablename varchar,start_date varchar,end_date varchar,ptype varchar,pcolumn varchar)

    RETURNS text

AS $$

    import re

    import datetime

    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值