Список всех таблиц в postgresql information_schema

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

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

Ответ 1

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

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

Ответ 2

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

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

Он отображает только список создаваемых таблиц.

Ответ 3

\dt information_schema.

из psql, должно быть хорошо.

Ответ 4

Команда "\ z" COMMAND также является хорошим способом перечислить таблицы в интерактивном сеансе 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)

Ответ 5

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

select * from pg_tables where schemaname = 'information_schema'

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

Ответ 6

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

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

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

Ответ 7

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

select * from information_schema.tables

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

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

Ответ 8

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. получить только таблицы

select * from information_schema.tables
    where table_schema not in ('information_schema', 'pg_catalog') and
    table_type = 'BASE TABLE'