| From: | barry kimelman <perlmaster56(at)gmail(dot)com> | 
|---|---|
| To: | pgsql-novice(at)lists(dot)postgresql(dot)org | 
| Subject: | postgresql rookie needs help with system catalog | 
| Date: | 2020-01-22 14:51:58 | 
| Message-ID: | CAEOpmvoj8itCG-c9fOABreWZ1YjJL-Zp-Ern5=SzCxfihhiBkw@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-novice | 
I am trying to come up with a query of the system catalog tables to give me
the same info as the psql command "\d tablename"
so far I have come up with the following query
  1 SELECT
  2        a.attname as "Column",
  3        pg_catalog.format_type(a.atttypid, a.atttypmod) as "Datatype"
  4    FROM
  5        pg_catalog.pg_attribute a
  6    WHERE
  7        a.attnum > 0
  8        AND NOT a.attisdropped
  9        AND a.attrelid = (
 10            SELECT c.oid
 11            FROM pg_catalog.pg_class c
 12                LEFT JOIN pg_catalog.pg_namespace n ON n.oid =
c.relnamespace
 13            WHERE c.relname = 'laptop'
 14                AND pg_catalog.pg_table_is_visible(c.oid)
 15        );
which yields the following result
    Column     |        Datatype
---------------+------------------------
 id            | integer
 name          | character varying(250)
 price         | double precision
 purchase_date | date
(4 rows)
But how do I get the Collation and Nullable and Default values displayed by
the "psql \d" command ?
Thanks.
-- 
Barrry Kimelman
Winnipeg, Manitoba, Canada
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Vianello, Dan A | 2020-01-22 15:05:29 | RE: postgresql rookie needs help with system catalog | 
| Previous Message | Tom Lane | 2020-01-17 21:39:35 | Re: postgresql rookie needs help initial setup help |