Re: pg_relation_size on partitioned table - Mailing list pgsql-hackers

From Bharath Rupireddy
Subject Re: pg_relation_size on partitioned table
Date
Msg-id CALj2ACX7jZeaUbGvH1m94v6g4e+T8=EkiXAbeYkWwZHbPE-WcQ@mail.gmail.com
Whole thread Raw
In response to pg_relation_size on partitioned table  (Japin Li <japinli@hotmail.com>)
Responses Re: pg_relation_size on partitioned table
Re: pg_relation_size on partitioned table
List pgsql-hackers
On Fri, Mar 25, 2022 at 6:23 PM Japin Li <japinli@hotmail.com> wrote:
>
> Hi, hackers
>
> When I try to get total size of partition tables though partitioned table
> name using pg_relation_size(), it always returns zero.  I can use the
> following SQL to get total size of partition tables, however, it is a bit
> complex.
>
>     SELECT
>         pg_size_pretty(sum(pg_relation_size(i.inhrelid)))
>     FROM
>         pg_class c JOIN pg_inherits i ON c.oid = i.inhparent
>     WHERE
>         relname = 'parent';
>
> Could we provide a function to get the total size of the partition table
> though the partitioned table name?  Maybe we can extend
> the pg_relation_size() to get the total size of partition tables through
> the partitioned table name.

If we want to have it in the core, why can't it just be a function (in
system_functions.sql) something like below? Not everyone, would know
how to get partition relation size, especially whey they are not using
psql, they can't use the short forms that it provides.

CREATE OR REPLACE FUNCTION pg_partition_relation_size(regclass)
 RETURNS bigint
 LANGUAGE sql
 PARALLEL SAFE STRICT COST 1
BEGIN ATOMIC
     SELECT
         pg_size_pretty(sum(pg_relation_size(i.inhrelid)))
     FROM
         pg_class c JOIN pg_inherits i ON c.oid = i.inhparent
     WHERE
         relname = '$1';
END;

Regards,
Bharath Rupireddy.



pgsql-hackers by date:

Previous
From: Justin Pryzby
Date:
Subject: Re: CREATE INDEX CONCURRENTLY on partitioned index
Next
From: Robert Haas
Date:
Subject: Re: Corruption during WAL replay