位置: 编程技术 - 正文

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

  • 可变现净值相关税费包括消费税吗
  • 预缴增值税的会计账务处理
  • 挂靠到运输公司的车转让给个人如何交增值税
  • 每个月结转损益都有什么科目
  • 实收资本增加印花税税目
  • 外贸公司有国企吗
  • 预提返利的会计处理
  • 含运费的原材料会计分录
  • 承包费收入计入什么科目
  • 超额亏损在合并后怎么算
  • 个人汽车租赁发票网上怎么开
  • 个人独资企业核定
  • 外地预缴个人所得税会计分录
  • 取得甲供材料按简易征收发票能抵扣吗
  • 溢价转让股权的会计处理
  • 加工费月底需要全部结转吗
  • 我的初级备考经验------极限挑战,超越自我
  • 小规模纳税人专票开3%的专票,以后就不能享受1%
  • 服装加工费发票税点
  • bios设置技巧
  • m1 mac 恢复出厂
  • 五险一金个人缴纳部分
  • 文档自动填写怎么弄
  • 合同条款签订
  • 个人所得税和企业所得税都要交吗
  • 包装物押金收入含税吗
  • 增值税专用发票丢了怎么补救
  • win7如何打开管理员权限
  • 房地产企业将开发产品抵押后再销售
  • 其他应付款不用付了怎么处理
  • 公司员工培训后的收获和感想
  • 生产性生物资产折旧账务处理
  • 商业折扣影响入账金额吗
  • phpinfo() 中 Local Value(局部变量)Master Value(主变量) 的区别
  • ai绘图素材
  • 分公司注销,总公司账务处理
  • 建筑服务需要开外经证吗
  • 公司给员工付个税怎么算
  • php中的函数
  • 老税号的发票还能认证吗
  • 旅游公司差额征税税率是5%
  • 增值税普通发票税率
  • 亏损合同预计负债的会计分录
  • css中字符间距怎么设置
  • 人力资源公司开票税目
  • 没有实收资本的股权原值
  • 在linux服务器中新增加一块硬盘
  • dede织梦怎么转成zblog
  • 清算机构收单机构和发卡行
  • 专票抵扣进项税额怎么填申报表呢
  • 公司减少注册资本的条件和程序
  • 小企业会计准则适用于哪些企业
  • 房屋租赁合同印花税怎么交,一年一次吗
  • 财务费用的内容包括哪些
  • 财务负责人岗位要求
  • 一般纳税人的增值税税率
  • 持有至到期投资是债权投资吗
  • 政府部门城投公司融资安全吗
  • 享受小微企业免征增值税政策
  • 用友关账怎么取消
  • 受托代销商品款计入存货吗
  • 报销管理规定
  • 清卡流程图
  • 安装sql2000sp4提示挂起
  • windows8.
  • win7密码输入错误被锁住
  • w8网络设置
  • win10蓝屏故障
  • win8.1专业版怎么升级成win10
  • 围绕摄像机旋转怎么设置
  • unity hud优化
  • easyui combobox设置值
  • python 单例
  • js跨域解决方案有哪些
  • javascript取随机数
  • 哈尔滨工业大学录取分数线2023年
  • 扬州地方税务局在哪
  • 工会开票要求
  • 地税局属于省直单位吗
  • 青岛税务局局长是什么级别?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设