• 技术文章 >数据库 >PostgreSQL

    postgresql查询分区表怎么查

    silencementsilencement2020-03-02 16:08:27原创11348

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

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

    查询指定分区表信息

    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';

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

    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’,下面是我在生产库查询的例子。

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

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

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

    专题推荐:数据库
    上一篇:postgresql如何快速导入数据库 下一篇:postgresql存储过程是什么

    相关文章推荐

    • linux下如何查看是否安装postgresql• postgresql怎么导入表

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网