On 2017/09/06 19:14, Amit Langote wrote:
> On 2017/09/06 18:46, Rushabh Lathia wrote:
>> Okay, I have marked this as ready for committer.
> 
> Thanks Ashutosh and Rushabh for rebasing and improving the patch.  Looks
> good to me too.

Patch needed to be rebased after the default partitions patch went in, so
done.  Per build status on http://commitfest.cputube.org :)

Thanks,
Amit
From 0ac21ff604b5dccf818f9d69c945ff845d1771bf Mon Sep 17 00:00:00 2001
From: amit <amitlangot...@gmail.com>
Date: Wed, 13 Sep 2017 09:56:34 +0900
Subject: [PATCH] Some enhancments for \d+ output of partitioned tables

---
 src/bin/psql/describe.c                    | 32 ++++++++++++++++++++++++------
 src/test/regress/expected/create_table.out | 13 +++++++-----
 src/test/regress/expected/foreign_data.out |  3 +++
 src/test/regress/expected/insert.out       | 17 ++++++++++++++++
 src/test/regress/sql/create_table.sql      |  2 +-
 src/test/regress/sql/insert.sql            |  4 ++++
 6 files changed, 59 insertions(+), 12 deletions(-)

diff --git a/src/bin/psql/describe.c b/src/bin/psql/describe.c
index d22ec68431..855e6870e9 100644
--- a/src/bin/psql/describe.c
+++ b/src/bin/psql/describe.c
@@ -2831,7 +2831,7 @@ describeOneTableDetails(const char *schemaname,
                /* print child tables (with additional info if partitions) */
                if (pset.sversion >= 100000)
                        printfPQExpBuffer(&buf,
-                                                         "SELECT 
c.oid::pg_catalog.regclass, pg_catalog.pg_get_expr(c.relpartbound, c.oid)"
+                                                         "SELECT 
c.oid::pg_catalog.regclass, pg_get_expr(c.relpartbound, c.oid), c.relkind"
                                                          " FROM 
pg_catalog.pg_class c, pg_catalog.pg_inherits i"
                                                          " WHERE 
c.oid=i.inhrelid AND i.inhparent = '%s'"
                                                          " ORDER BY 
c.oid::pg_catalog.regclass::pg_catalog.text;", oid);
@@ -2854,7 +2854,18 @@ describeOneTableDetails(const char *schemaname,
                else
                        tuples = PQntuples(result);
 
-               if (!verbose)
+               /*
+                * For a partitioned table with no partitions, always print the 
number
+                * of partitions as zero, even when verbose output is expected.
+                * Otherwise, we will not print "Partitions" section for a 
partitioned
+                * table without any partitions.
+                */
+               if (tableinfo.relkind == RELKIND_PARTITIONED_TABLE && tuples == 
0)
+               {
+                       printfPQExpBuffer(&buf, _("Number of partitions: %d"), 
tuples);
+                       printTableAddFooter(&cont, buf.data);
+               }
+               else if (!verbose)
                {
                        /* print the number of child tables, if any */
                        if (tuples > 0)
@@ -2886,12 +2897,21 @@ describeOneTableDetails(const char *schemaname,
                                }
                                else
                                {
+                                       char       *partitioned_note;
+
+                                       if (*(PQgetvalue(result, i, 2)) == 
RELKIND_PARTITIONED_TABLE)
+                                               partitioned_note = " is 
partitioned";
+                                       else
+                                               partitioned_note = "";
+
                                        if (i == 0)
-                                               printfPQExpBuffer(&buf, "%s: %s 
%s",
-                                                                               
  ct, PQgetvalue(result, i, 0), PQgetvalue(result, i, 1));
+                                               printfPQExpBuffer(&buf, "%s: %s 
%s%s",
+                                                                               
  ct, PQgetvalue(result, i, 0), PQgetvalue(result, i, 1),
+                                                                               
  partitioned_note);
                                        else
-                                               printfPQExpBuffer(&buf, "%*s  
%s %s",
-                                                                               
  ctw, "", PQgetvalue(result, i, 0), PQgetvalue(result, i, 1));
+                                               printfPQExpBuffer(&buf, "%*s  
%s %s%s",
+                                                                               
  ctw, "", PQgetvalue(result, i, 0), PQgetvalue(result, i, 1),
+                                                                               
  partitioned_note);
                                }
                                if (i < tuples - 1)
                                        appendPQExpBufferChar(&buf, ',');
diff --git a/src/test/regress/expected/create_table.out 
b/src/test/regress/expected/create_table.out
index 58c755be50..0a4316f269 100644
--- a/src/test/regress/expected/create_table.out
+++ b/src/test/regress/expected/create_table.out
@@ -428,13 +428,15 @@ ERROR:  cannot inherit from partitioned table 
"partitioned2"
  c      | text    |           |          | 
  d      | text    |           |          | 
 Partition key: RANGE (a oid_ops, plusone(b), c, d COLLATE "C")
+Number of partitions: 0
 
-\d partitioned2
-            Table "public.partitioned2"
- Column |  Type   | Collation | Nullable | Default 
---------+---------+-----------+----------+---------
- a      | integer |           |          | 
+\d+ partitioned2
+                               Table "public.partitioned2"
+ Column |  Type   | Collation | Nullable | Default | Storage | Stats target | 
Description 
+--------+---------+-----------+----------+---------+---------+--------------+-------------
+ a      | integer |           |          |         | plain   |              | 
 Partition key: LIST (((a + 1)))
+Number of partitions: 0
 
 DROP TABLE partitioned, partitioned2;
 --
@@ -788,5 +790,6 @@ SELECT obj_description('parted_col_comment'::regclass);
  a      | integer |           |          |         | plain    |              | 
Partition key
  b      | text    |           |          |         | extended |              | 
 Partition key: LIST (a)
+Number of partitions: 0
 
 DROP TABLE parted_col_comment;
diff --git a/src/test/regress/expected/foreign_data.out 
b/src/test/regress/expected/foreign_data.out
index c6e558b07f..e8e29aa954 100644
--- a/src/test/regress/expected/foreign_data.out
+++ b/src/test/regress/expected/foreign_data.out
@@ -1882,6 +1882,7 @@ DROP FOREIGN TABLE pt2_1;
  c2     | text    |           |          |         | extended |              | 
  c3     | date    |           |          |         | plain    |              | 
 Partition key: LIST (c1)
+Number of partitions: 0
 
 CREATE FOREIGN TABLE pt2_1 (
        c1 integer NOT NULL,
@@ -1966,6 +1967,7 @@ ALTER TABLE pt2 ALTER c2 SET NOT NULL;
  c2     | text    |           | not null |         | extended |              | 
  c3     | date    |           |          |         | plain    |              | 
 Partition key: LIST (c1)
+Number of partitions: 0
 
 \d+ pt2_1
                                       Foreign table "public.pt2_1"
@@ -1995,6 +1997,7 @@ ALTER TABLE pt2 ADD CONSTRAINT pt2chk1 CHECK (c1 > 0);
 Partition key: LIST (c1)
 Check constraints:
     "pt2chk1" CHECK (c1 > 0)
+Number of partitions: 0
 
 \d+ pt2_1
                                       Foreign table "public.pt2_1"
diff --git a/src/test/regress/expected/insert.out 
b/src/test/regress/expected/insert.out
index 73a5600f19..046bc27d1d 100644
--- a/src/test/regress/expected/insert.out
+++ b/src/test/regress/expected/insert.out
@@ -382,6 +382,23 @@ select tableoid::regclass::text, a, min(b) as min_b, 
max(b) as max_b from list_p
  part_null     |    |     1 |     1
 (9 rows)
 
+-- test \d+ output on a table which has both partitioned and unpartitioned
+-- partitions
+\d+ list_parted
+                                Table "public.list_parted"
+ Column |  Type   | Collation | Nullable | Default | Storage  | Stats target | 
Description 
+--------+---------+-----------+----------+---------+----------+--------------+-------------
+ a      | text    |           |          |         | extended |              | 
+ b      | integer |           |          |         | plain    |              | 
+Partition key: LIST (lower(a))
+Partitions: part_aa_bb FOR VALUES IN ('aa', 'bb'),
+            part_cc_dd FOR VALUES IN ('cc', 'dd'),
+            part_default DEFAULT is partitioned,
+            part_ee_ff FOR VALUES IN ('ee', 'ff') is partitioned,
+            part_gg FOR VALUES IN ('gg') is partitioned,
+            part_null FOR VALUES IN (NULL),
+            part_xx_yy FOR VALUES IN ('xx', 'yy') is partitioned
+
 -- cleanup
 drop table range_parted, list_parted;
 -- test that a default partition added as the first partition accepts any value
diff --git a/src/test/regress/sql/create_table.sql 
b/src/test/regress/sql/create_table.sql
index eeab5d91ff..a9195b72c6 100644
--- a/src/test/regress/sql/create_table.sql
+++ b/src/test/regress/sql/create_table.sql
@@ -421,7 +421,7 @@ CREATE TABLE fail () INHERITS (partitioned2);
 
 -- Partition key in describe output
 \d partitioned
-\d partitioned2
+\d+ partitioned2
 
 DROP TABLE partitioned, partitioned2;
 
diff --git a/src/test/regress/sql/insert.sql b/src/test/regress/sql/insert.sql
index a2948e4dd0..2fdd751a71 100644
--- a/src/test/regress/sql/insert.sql
+++ b/src/test/regress/sql/insert.sql
@@ -222,6 +222,10 @@ insert into list_parted select 'gg', s.a from 
generate_series(1, 9) s(a);
 insert into list_parted (b) values (1);
 select tableoid::regclass::text, a, min(b) as min_b, max(b) as max_b from 
list_parted group by 1, 2 order by 1;
 
+-- test \d+ output on a table which has both partitioned and unpartitioned
+-- partitions
+\d+ list_parted
+
 -- cleanup
 drop table range_parted, list_parted;
 
-- 
2.11.0

-- 
Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-hackers

Reply via email to