Список всех таблиц в postgresql information_schema - PullRequest
149 голосов
/ 17 февраля 2010

Каков наилучший способ перечислить все таблицы в information_schema PostgreSQL?

Чтобы уточнить: я работаю с пустой БД (я не добавил ни одной из своих собственных таблиц), но хочу видеть каждую таблицу в структуре information_schema.

Ответы [ 8 ]

211 голосов
/ 17 февраля 2010

Вы можете просто запустить select * from information_schema.tables, чтобы получить список каждой таблицы, управляемой Postgres для конкретной базы данных.

Вы также можете добавить where table_schema = 'information_schema', чтобы увидеть только таблицы в информационной схеме.

84 голосов
/ 30 августа 2012

Для перечисления ваших таблиц используйте:

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

В нем будут только те таблицы, которые вы создали.

37 голосов
/ 17 февраля 2010
\dt information_schema.

изнутри psql, должно быть в порядке.

12 голосов
/ 07 июля 2014

КОМАНДА "\ z" также является хорошим способом отображения таблиц в интерактивном сеансе psql.

например.

# psql -d mcdb -U admin -p 5555
mcdb=# /z
                           Access privileges for database "mcdb"
 Schema |              Name              |   Type   |           Access privileges
--------+--------------------------------+----------+---------------------------------------
 public | activities                     | table    |
 public | activities_id_seq              | sequence |
 public | activities_users_mapping       | table    |
[..]
 public | v_schedules_2                  | view     | {admin=arwdxt/admin,viewuser=r/admin}
 public | v_systems                      | view     |
 public | vapp_backups                   | table    |
 public | vm_client                      | table    |
 public | vm_datastore                   | table    |
 public | vmentity_hle_map               | table    |
(148 rows)
8 голосов
/ 16 мая 2013

Вы также можете использовать

select * from pg_tables where schemaname = 'information_schema'

В общем pg * таблицы позволяют вам видеть все в БД, не ограниченные вашими разрешениями (если вы, конечно, имеете доступ к таблицам).

5 голосов
/ 01 марта 2014

Для частной схемы 'xxx' в postgresql:

SELECT table_name FROM information_schema.tables 
 WHERE table_schema = 'xxx' AND table_type = 'BASE TABLE'

Без table_type = 'BASE TABLE' вы увидите список таблиц и просмотров

2 голосов
/ 21 января 2019

1.получить все таблицы и представления из information_schema.tables, включая таблицы information_schema и pg_catalog

select * from information_schema.tables

2. Получают таблицы и представления принадлежат определенной схеме

select * from information_schema.tables
    where table_schema not in ('information_schema', 'pg_catalog')

3.Получать только таблицы (почти \ dt)

select * from information_schema.tables
    where table_schema not in ('information_schema', 'pg_catalog') and
    table_type = 'BASE TABLE'
1 голос
/ 07 февраля 2018

Если вы хотите быстрый и грязный однострочный запрос:

select * from information_schema.tables

Вы можете запустить его непосредственно в инструменте Query, не открывая psql.

(Другие посты предлагают более конкретные запросы information_schema, но, как новенький, я считаю, что этот однострочный запрос помогает мне разобраться с таблицей)

...