当前位置:首页 > 云计算 > 正文内容

postgresql查询分区表怎么查

2022-05-04 03:20:06云计算4

大家知道 PostgreSQL 的分区是通过继承来实现的,按分区方式,可以实现表的列表分区,范围分区,以及复合分区等,本文仅介绍关于

分区表的几个查询,方便维护和管理分区表。

查询指定分区表信息

SELECT
nmsp_parent.nspnameASparent_schema,
parent.relnameASparent,
nmsp_child.nspnameASchild,
child.relnameASchild_schema
FROM
pg_inheritsJOINpg_classparent
ONpg_inherits.inhparent=parent.oidJOINpg_classchild
ONpg_inherits.inhrelid=child.oidJOINpg_namespacenmsp_parent
ONnmsp_parent.oid=parent.relnamespaceJOINpg_namespacenmsp_child
ONnmsp_child.oid=child.relnamespace
WHERE
parent.relname='table_name';

查询库中所有分区表子表个数

SELECT
nspname,
relname,
COUNT(*)ASpartition_num
FROM
pg_classc,
pg_namespacen,
pg_inheritsi
WHERE
c.oid=i.inhparent
ANDc.relnamespace=n.oid
ANDc.relhassubclass
ANDc.relkind='r'
GROUPBY1,2ORDERBYpartition_numDESC;

备注:如果表是分区表,那么相应的 pg_class.relhassubclass 字段为 ‘t’,否则为 ‘f’,下面是我在生产库查询的例子。

备注:第一张表分区表子表个数为 940,第二张表分区表子表个数为 842,这两张表为按日分区,后面的表为按月分区,按月分区的表个

数有差异,因为有些表快到期了,需要扩分区,有些分区表数据有清理策略,维护时删除了一些子表。

更多技术请关注Python视频教程。

本网站文章仅供交流学习 ,不作为商用, 版权归属原作者,部分文章推送时未能及时与原作者取得联系,若来源标注错误或侵犯到您的权益烦请告知,我们将立即删除.

本文链接:https://www.xibujisuan.cn/13210.html

标签: Python