位置: 编程技术 - 正文

PostgreSQL之分区表(partitioning)

发布时间:2024-01-29

推荐整理分享PostgreSQL之分区表(partitioning),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

PostgreSQL有一项非常有用的功能,分区表,或者partitioning。当某个TABLE的记录非常的多,千万甚至更多的时候,我们其实需要将他分割成子表。一个庞大的TABLE,就像水果仓库杂乱无章地堆放着无数的苹果桃子和桔子,查找不方便,性能降低,比较合理的做法是将仓库分成三个子区域,分表放苹果桃子和桔子。一张大表就变成了三个小表的集合。

通过合理的设计,可以将选择一定的规则,将大表切分多个不重不漏的子表,这就是传说中的partitioning。比如,我们可以按时间切分,每天一张子表,比如我们可以按照某其他字段分割,总之了就是化整为零,提高查询的效能。

怎么实现这个分区表的功能呢? 1 建立大表。 2 创建分区继承 3 定义Rule或者Trigger?

下面根据一个简单的例子,描述这个过程。我们将学生按照低于分和不低于分切分成两张子表。

1 建立大表

2 创建分区继承。

创建了两个分区表,student_qualified和student_nqualified,继承了大表student的一切字段,同时设定了约束,即CHECK条件。

3 定义Rule或者Trigger。

虽然我们定义了CHECK条件,但是往student插入数据时,PostgreSQL并不能根据score是否低于插入的正确的子表,原因是,你并没有定义这种规则,来告诉数据这么做。我们需要定义Rule或者Trigger,将数据插入到正确的分区表。 先看下Rule的定义:

这两个Rule告诉了PostgreSQL,当往总表插数据的时候,如果是score< ,则插入student_nqualified,如果score>=,则插入student_qualified.注意了,这个分割一定要不重不漏,如果我们不小心将>=条件的“=”丢掉,等于分的记录将会录入大表student,不在任何一个分区表中。我们插入一些记录:

我们看下数据分布情况,是否分布到了正确的的分区表:

输出如下:

我们看到,虽然我们插入的是大表,但是数据却存在了对应的分区子表。符合我们的期望。同时还不影响查询。

PostgreSQL之分区表(partitioning)

Rule是一个分流的办法,还有TRIGGER也能做到让正确的数据流向正确的分区子表。首先我们定义个function。

然后定义TRIGGER,当插入到student之前,就会触发trigger:

我们首先通过删除TABLE student,测试下trigger方式。

然后执行定义FUNCTION和定义TRIGGER的语句。就可以查看了。为了确认我们的触发器的确触发了,我们打开存储过程的统计开关:在postgresql.conf中,找到track_functions,改成all

track_functions = all

插入之前先看下function student_insert_trigger的统计信息:

执行插入:

插入后,看下function student_insert_trigger的统计信息

我们看到trigger触发了6次。执行下查询:

输出如下:

参考文献

1 PostgreSQL document

CentOS 7下安装PostgreSQL 9.6的教程分享 前言PostgreSQL是一个强大开源的对象关系类型数据库系统,它能运行于几乎所有主要的操作系统,包括Linux、Unix(AIX、BSD、HP-UX、SGIIRIX、MacOS、Solaris、Tru)

Windows上PostgreSQL安装配置教程 PostgreSQL的扩展PostGIS是最著名的开源GIS数据库。安装PostgreSQL是第一步。1.下载PostgreSQL的二进制安装文件。PostgreSQL官网?Download?Windows位,如图所示:(1

Windows下Postgresql下载与配置方法 注意下载的是二进制版,不是带WindowsInstaller的,即绿色版本

标签: PostgreSQL之分区表(partitioning)

本文链接地址:https://www.jiuchutong.com/biancheng/312226.html 转载请保留说明!

上一篇:windows PostgreSQL 9.1 安装详细步骤

下一篇:CentOS 7下安装PostgreSQL 9.6的教程分享(centos7.3安装)

  • 纳税申报操作流程
  • 设备转产需要停止折旧吗
  • 事业单位资产负责比往年增加表明什么
  • 公司货款退款怎么写
  • 飞机发票和行程单可以一起开吗
  • 纳税人等级怎么划分
  • 打印社保缴费凭证需要什么证件
  • 客户未付关税是否可以申请晚交
  • 未使用房子需要交物业费嘛
  • 运输费用 成本
  • 营改增后预交营业税怎么处理
  • 货运代理可以开9个点的发票吗?
  • 计算广告的基本运作模式
  • 附加税退税如何做账
  • 兼职人员工资个税怎么申报
  • 网上申领发票怎么清卡
  • 超过三年的坏帐损失税前扣除怎样规定?
  • 已认证抵扣的进项税额转出做账的会计处理
  • 技术服务的大类包括
  • 销售额不到10万免征什么税
  • 解决口苦最快的方法
  • 企业为开发新产品新技术新工艺
  • 一般纳税人如何计算企业所得税
  • linux系统情况
  • php parse_url
  • ahc软件进不去
  • phpunicode
  • u盘格式化后怎么还原数据
  • 跟银行借入长期存款
  • 不用指令
  • 小微企业所得税税收优惠政策2023年
  • 汇总开具的运输发票
  • 小企业会计准则财务报表至少包括
  • vue的number
  • controller控制器怎么调
  • 命令压缩文件
  • 华为mate主题
  • 公司有收入可不交社保吗
  • 工会经费支出实施细则
  • 工程结算是含有增值税吗
  • 税控盘开票机号在哪里能查到
  • mysql命令行实用程序
  • 社保为什么单位缴费是0什么时间才正常
  • mongodb operator
  • 转出多交增值税账务处理
  • 公司固定电话费用挂哪个科目
  • 应付职工薪酬的工资是实发工资还是应发工资
  • 折旧完的固定资产出售
  • 物业公司代收代付租金要开发票吗
  • 免费给人一些客户资料违法吗
  • 企业垫付是什么意思
  • 企业中的消费环境分析
  • 没有对公业务的银行
  • 会计怎么做的
  • 原始凭证的基本内容
  • window 开机启动
  • 2014年电脑装win7与win10
  • win7旗舰版系统还原无法启动
  • Win10 Build 10565快速预览版为什么有ISO镜像下载地址?
  • linux的用法
  • mac屏幕显示设置
  • linux系统ln命令
  • centos怎么样
  • win7硬盘访问权限怎么解除
  • linux配置文件命令
  • suse linux 12 sp5
  • linux如何使用gcc编译
  • css主要解决什么问题
  • node.js中的http.response.addTrailers方法使用说明
  • shell脚本获取本地ip
  • 主机端口扫描程序设计python
  • 封装好的中药能带上飞机吗
  • 如何查询企业税号
  • CA证书如何办理?
  • 手机申报税务不成功怎么办
  • 如何查询公司的电话号码
  • 包装物押金的计算
  • 江苏电子票据
  • 网上订机票怎么取票
  • 土地招拍挂土地出让金
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号