极客小将

您现在的位置是:首页 » python编程资讯

资讯内容

postgresql查询分区表怎么查

极客小将2021-01-08-
简介大家知道PostgreSQL的分区是通过继承来实现的,按分区方式,可以实现表的列表分区,范围分区,以及复合分区等,本文仅介绍关于分区表的几个查询,方便维护和管理分区表。查询指定分区表信息SELECT    nmsp_parent.nspname AS

uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

大家知道 PostgreSQL 的分区是通过继承来实现的,按分区方式,可以实现表的列表分区,范围分区,以及复合分区等,本文仅介绍关于uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

分区表的几个查询,方便维护和管理分区表。uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

查询指定分区表信息
uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

SELECT     nmsp_parent.nspname AS parent_schema ,     parent.relname AS parent ,     nmsp_child.nspname AS child ,     child.relname AS child_schema FROM     pg_inherits JOIN pg_class parent         ON pg_inherits.inhparent = parent.oid JOIN pg_class child         ON pg_inherits.inhrelid = child.oid JOIN pg_namespace nmsp_parent         ON nmsp_parent.oid = parent.relnamespace JOIN pg_namespace nmsp_child         ON nmsp_child.oid = child.relnamespace WHERE     parent.relname = 'table_name';

查询库中所有分区表子表个数
uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

SELECT     nspname ,     relname ,     COUNT(*) AS partition_num FROM     pg_class c ,     pg_namespace n ,     pg_inherits i WHERE     c.oid = i.inhparent     AND c.relnamespace = n.oid     AND c.relhassubclass     AND c.relkind = 'r' GROUP BY 1,2 ORDER BY partition_num DESC;

备注:如果表是分区表,那么相应的 pg_class.relhassubclass 字段为 ‘t’,否则为 ‘f’,下面是我在生产库查询的例子。uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

备注:第一张表分区表子表个数为 940,第二张表分区表子表个数为 842,这两张表为按日分区,后面的表为按月分区,按月分区的表个uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

数有差异,因为有些表快到期了,需要扩分区,有些分区表数据有清理策略,维护时删除了一些子表。uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

更多技术请关注python视频教程。uH7少儿编程网-Scratch_Python_教程_免费儿童编程学习平台

网友点评

共有5条评论来说两句吧...

在线客服