Re: list all columns in db - Mailing list pgsql-general

From Peter Childs
Subject Re: list all columns in db
Date
Msg-id a2de01dd0706080021q4f0746e5h59ed95d32da7a5e2@mail.gmail.com
Whole thread Raw
In response to Re: list all columns in db  (Jon Sime <jsime@mediamatters.org>)
Responses Re: list all columns in db
List pgsql-general


On 07/06/07, Jon Sime <jsime@mediamatters.org> wrote:
Jonathan Vanasco wrote:
>
> Does anyone have a trick to list all columns in a db ?

No trickery, just exploit the availability of the SQL standard
information_schema views:

     select table_schema, table_name, column_name
     from information_schema.columns
     where table_schema not in ('pg_catalog','information_schema')
     order by 1,2,3


Is there any easy way to remove the views from the query?

Peter.
 

If you want an equivalent that uses pg_catalog (non-portable outside of
PostgreSQL) you could instead do:

     select n.nspname as table_schema, c.relname as table_name,
         a.attname as column_name
     from pg_catalog.pg_attribute a
         join pg_catalog.pg_class c on ( a.attrelid = c.oid)
         join pg_catalog.pg_namespace n on (c.relnamespace = n.oid)
     where c.relkind in ('r','v') and a.attnum > 0
         and n.nspname not in ('pg_catalog','information_schema')
     order by 1,2,3

-Jon

--
Senior Systems Developer
Media Matters for America
http://mediamatters.org/

---------------------------(end of broadcast)---------------------------
TIP 5: don't forget to increase your free space map settings

pgsql-general by date:

Previous
From: Tom Lane
Date:
Subject: Re: What's the correct way to use FunctionCallInvoke()?
Next
From: Samatha Kottha
Date:
Subject: Re: setting login database