位置: 编程技术 - 正文

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安装)

  • 文化事业建设税怎么申报
  • 支付的运输费用计入什么科目
  • 杭天金税财务软件多少钱
  • 财产租赁所得怎么计算个人所得税
  • 计入资本公积的固定资产报废
  • 企业所得税季末从业人数怎么填
  • 给员工发开门红包的通知
  • 免征的附加税是什么
  • 以前年度损益调整借贷方向
  • 一般纳税人转让二手车增值税税率
  • 错账更正分录
  • 融资租赁租金会计科目
  • 管家婆进货单科目名称怎么录入?
  • 接受投资者的无形资产
  • 税控盘上开完发票发的邮件在哪查看
  • 其他业务收入需要结转成本吗
  • 2018增值税暂行条例
  • 固定资产的入账价值怎么计算
  • 车辆购置税固定资产
  • 有关增值税期末留抵税额的会计分录
  • 受让无形资产是什么意思
  • 定金转为货款金额需要特别约定吗?
  • 在会计上其他业务是什么
  • 资产处置收益属于利润表项目吗
  • 记账凭证做完之后干什么
  • 财务计提个人缴纳社保部分怎么记账?
  • 在windows7的
  • 合同终止后发生的效果包括
  • 长期债权投资收回的利息 现金流量表
  • 软件和硬件的成本按销售占比做分摊怎么算
  • flash player用不了怎么办
  • mac菜单键怎么设置出来的
  • 一年以上预收账款
  • php怎么读取txt
  • PHP:JDToGregorian()的用法_日历函数
  • debian更换国内源教程
  • 夕阳下的大白鲨过山车,美国新泽西州 (© John Van Decker/Alamy)
  • 增值税注明的价款是含税还是不含税
  • Vue3通透教程【二】更高效的构建工具—Vite
  • 验证码php代码
  • 员工通行费合法报销
  • 对方公司开收据盖什么章
  • 货物运输业增值税
  • 变更法人需要什么流程
  • 咨询服务费怎么交税
  • 开具培训类发票需要哪些条件?
  • python中的函数调用
  • 银行承兑汇票回头背书
  • sqlmap暴力破解
  • 企业应付账款的借方登记
  • 装修公司财务报表图片
  • 公司内部的往来款用什么表格怎么做账
  • 外币账户的钱怎么转成人民币
  • 企业取得财产转让收入
  • 职工食堂的费用,会计上怎么做账?
  • 个人工资怎么合理避税有什么方法
  • 老板借给公司钱需要交税吗
  • 工程材料如何管理
  • 其他权益工具包括交易性金融资产吗
  • 企业叉车折旧年限几年
  • 投资入股行为
  • 税控盘服务费什么样的发票可以抵扣
  • 冲暂估成本能冲部分暂估吗
  • c# mysql实例
  • sql server本地登录
  • win7怎么删除win10系统
  • win8系统怎么重置
  • 让Windows Server 2008设备驱动安装图文教程
  • win7系统对拷的方法
  • xp系统盘空间不足怎么办
  • win10连无线网络受限
  • win7找不到启动
  • bat批处理命令大全
  • Cocos2dx -lua QuickXDev拓展
  • html中滚动条
  • javascript模块化规范
  • 设计模式具有的优点
  • python if none
  • 我们要什么行政执法监督机制和能力建设严格落实行政
  • 长春税务局电话举报
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设