postgresql分区表

当我们数据库表数据量比较大,查询经常根据特定字段划分,比如时间,区县,这时候可以考虑采用分区表来提升查询效率和减轻对数据库的压力。

分区表的介绍请看这里:

PostgreSQL数据库表分区介绍-四种分区方式_postgresql 分区_tiger_angel的博客-CSDN博客

其实跟oracle创建分区表原理类似,都是把数据分开存储,查询的时候单独去检索这一块。不同的是pg是以子表的形式创建的分区,我们可以单独去查询或者增删改这个子分区表,不过实际上这个表在数据库对象里是看不到的,他依然属于主表的结构类型。oracle是直接对分区表进行创建分区,不存在子分区表这一说。

接下来我们测试下分区表的效率。(我这里用的是空间表,字段较多,所以综合查询比较慢)

这里我对区县字段创建了分区表、分区子表,并抽取单独一个区的物理表,原始总表数据,把数据插入后,保持同样的索引结构,对这四个表进行查询测试。随机查询20000条数据。

1、查询原始表 考虑到缓存问题,多次测试后用时6s~9s

2、查询分区总表 考虑到缓存问题,多次测试后用时4s左右

3、查询分区子表 考虑到缓存问题,多次测试后用时4s-5s左右(带不带查询条件都一样)

4、查询单区物理表 考虑到缓存问题,多次测试后用时4s左右 (带不带查询条件都一样)

最终结论:

通过单张物理表、单张分区表、分区总表、原始总表分别测试2万条数据查询结果:

1、单张分区表和单张物理表效率差不多,两者都高于原始表;

2、单张分区表和分区总表查询效果是一样的;

对于分区表增删改,操作分区子表和分区总表是一样的。

相关推荐
qq_41384740几秒前
如何脱机维护表空间数据文件_OFFLINE与ONLINE状态的切换场景
jvm·数据库·python
OpenClawCSDN2 分钟前
2026年腾讯云如何安装和集成Hermes Agent/OpenClaw?深度剖析
数据库·阿里云·云计算·腾讯云·京东云
鸽芷咕4 分钟前
Oracle迁移到KingbaseES实战:语法差异、函数映射与避坑指南
数据库·oracle
四维迁跃4 分钟前
Python Selenium怎么定位元素_By.XPATH与By.CSS_SELECTOR操作DOM节点
jvm·数据库·python
qq_3721542313 分钟前
CSS如何改变单个网格项目的对齐方式
jvm·数据库·python
kexnjdcncnxjs14 分钟前
CodeIgniter4安全加固指南:防御XSS与CSRF攻击
jvm·数据库·python
2401_8714928514 分钟前
Imagick PDF 处理失败的常见原因与解决方案
jvm·数据库·python
小年糕是糕手18 分钟前
【C/C++刷题集】栈、stack、队列、queue核心精讲
c语言·开发语言·数据结构·数据库·c++·算法·蓝桥杯
鸽芷咕22 分钟前
KingbaseES与Oracle兼容性深度解析:数据类型、内置函数、PL/SQL全面对比
数据库·sql·oracle
2301_8084143831 分钟前
MySQL数据类型
数据库·mysql