位置: 编程技术 - 正文

PostgreSQL之分区表(partitioning)

编辑:rootadmin

推荐整理分享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安装)

  • 电子承兑对方拒绝签收
  • 红字发票抵扣联丢了怎么办
  • 处置长投时其他权益变动
  • 现金股利缴纳个人所得税
  • 工会费缴纳基数
  • 车船税是费用吗
  • 附加税减半征收政策从什么时候开始
  • 资产减值损失借贷方向
  • 车辆报废收入如何处理
  • 补提折旧调整分录
  • 有限合伙企业经营期限多久
  • 对以前年度的收入调整
  • 出租厂房的摊销额会计分录
  • 工会经费购买发的东西要算个税吗?
  • 代开专用发票缴纳的增值税需要计提吗?
  • 营改增后不动产进项税额抵扣
  • 安全教育经费计算方法
  • 计提本月银行借款
  • 新开办公司前三个月没交社保,后面正常缴纳
  • qq画画图片大全
  • 教你从脸上看出风水
  • h5实现扫码功能
  • deepin 20 wifi
  • php date_diff
  • win10插usb没有反应
  • 电脑每次开机都要磁盘检查是什么原因
  • 高新技术企业的研发费用加计扣除
  • pos机未入账怎么回事
  • 如何做批发
  • 贴现资金是信贷资金吗
  • 境外租赁要交什么税
  • 城市:天际线
  • 企业发生的现金折扣应计入什么费用
  • 代订住宿费报销
  • php获取当前页面url
  • php 模拟post
  • 保险代理人展业成本如何计算
  • 以前年度应交税费调账
  • 怎样回到一年前
  • 公司购买银行理财产品账务处理
  • 增值税及附加税费申报表附列资料一
  • 现金日记账怎么填
  • 初级会计实务中第二章第四节存货(5)费琪
  • 收到对方公司的货款怎么记账
  • 长期待摊费用会计分录
  • 土地承包费和土地租赁费收入记账
  • 银行利息收入怎么计算
  • 建筑工程劳务分包,工伤责任承担
  • 房租押金是什么意思?
  • 销售折扣怎么制定
  • 收客户利息怎么处理
  • 招标付款条件及比例
  • 结账前要做哪些准备工作
  • window怎么样
  • win7更改电脑设置在哪里
  • mac电脑上的通讯录怎么同步到手机上
  • ubuntu设置共享文件夹命令mount
  • 隐藏文件或文件夹
  • win8怎么停止自动更新
  • win10登陆界面怎么关闭
  • win7系统怎么关闭防火墙设置
  • Win8开启SmartScreen筛选器保护上网安全
  • Perl实现高水线算法(解决多值比较问题方法)
  • js分页逻辑
  • Android游戏开发打砖块
  • 每天看30分钟手机可以吗
  • js中document.write
  • android方法大全
  • Node.js中的什么模块是用于处理文件和目录的
  • dns设置为网关会出现什么问题了
  • Unity3d-四元数到矩阵的实现
  • 喜大普奔含义
  • 沈阳地方税务局原局长
  • 甘肃车船使用税
  • 吉林省地方税务局单位职工集资建房免征营业税
  • 税控盘怎么领用
  • 深圳海吉星管理处电话
  • 什么是党建工作一体化
  • 跪式服务礼仪规范图片
  • 朝阳地税局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设