ChatGPT解决这个技术问题 Extra ChatGPT

List tables in a PostgreSQL schema

When I do a \dt in psql I only get a listing of tables in the current schema (public by default).

How can I get a list of all tables in all schemas or a particular schema?


R
Randall

In all schemas:

=> \dt *.*

In a particular schema:

=> \dt public.*

It is possible to use regular expressions with some restrictions

\dt (public|s).(s|t)
       List of relations
 Schema | Name | Type  | Owner 
--------+------+-------+-------
 public | s    | table | cpn
 public | t    | table | cpn
 s      | t    | table | cpn

Advanced users can use regular-expression notations such as character classes, for example [0-9] to match any digit. All regular expression special characters work as specified in Section 9.7.3, except for . which is taken as a separator as mentioned above, * which is translated to the regular-expression notation .*, ? which is translated to ., and $ which is matched literally. You can emulate these pattern characters at need by writing ? for ., (R+|) for R*, or (R|) for R?. $ is not needed as a regular-expression character since the pattern must match the whole name, unlike the usual interpretation of regular expressions (in other words, $ is automatically appended to your pattern). Write * at the beginning and/or end if you don't wish the pattern to be anchored. Note that within double quotes, all regular expression special characters lose their special meanings and are matched literally. Also, the regular expression special characters are matched literally in operator name patterns (i.e., the argument of \do).


Simply \dt is equivolent to \dt public.*, am I right?
How about, say, two specific tables in a specific schema? Like \dt public.user_info, public.user_scope?
Nevermind, it's easier just to do \dt public.a; \dt public.b; on one line.
it is kind of implicit.. If \dt gives only "public" tables, one would not expect anything more via regular expressions..
@FrozenFlame It is not! By default it shows whatever is in your search_path, and that defaults to "$user", public.*. Consequently, set search_path=s; \dt is going to list all tables in the schema s.
J
Jakub Kania

You can select the tables from information_schema

SELECT * FROM information_schema.tables 
WHERE table_schema = 'public'

very helpful if your interface doesn't support the shortcuts. thanks.
This is also nice because you could do something like select table_schema, table_name from information_schema.tables where table_name like '%whatever%'; if you need to know which schema the table is located in. Not sure you can do that with \dt
Thank you, it works on Amazon Redshift and \dt (accepted answer) doesn't.
This is the most generally useful answer. information_schema is defined in SQL Standards, and available on most databases that comply
To exclude views, put AND table_type = 'BASE TABLE' to the where clause.
R
Radek Postołowicz

Alternatively to information_schema it is possible to use pg_tables:

select * from pg_tables where schemaname='public';

note that if you only want the table name is the resultant query it is SELECT tablename FROM pg_tables WHERE schemaname = 'public';
Found a permissions issue with information_schema not listing items from the public schema, but the pg_tables method worked nicely. Many thanks!
P
Pang

For those coming across this in the future:

If you would like to see a list of relations for several schemas:

$psql mydatabase
mydatabase=# SET search_path TO public, usa;   #schema examples
SET
mydatabase=# \dt
              List of relations
 Schema |      Name       | Type  |  Owner
--------+-----------------+-------+----------
 public | counties        | table | postgres
 public | spatial_ref_sys | table | postgres
 public | states          | table | postgres
 public | us_cities       | table | postgres
 usa    | census2010      | table | postgres

l
linog

If you are interested in listing all tables in a particular schema, I found this answer relevant :

SELECT table_schema||'.'||table_name AS full_rel_name
  FROM information_schema.tables
 WHERE table_schema = 'yourschemaname';

To exclude views, put AND table_type = 'BASE TABLE' to the where clause.