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

140

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

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

Теги:
information-schema

8 ответов

197
Лучший ответ

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

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

  • 3
    Спасибо, я только что попробовал: / dt (звездочка). (Звездочка) это что-то другое?
  • 0
    Я ничего не знаю о / dt (звездочка). (Звездочка), извините. Я просто запустил запрос на выборку в postgres, и он перечислил информацию обо всех таблицах в нем. Попробуйте запустить оператор select (на вашей пустой базе данных) и посмотрите, что он возвращает.
Показать ещё 6 комментариев
77

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

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

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

  • 0
    Как насчет таблиц, которые вы не создаете, но у вас есть права доступа?
  • 3
    Это покажет только таблицы в общедоступной схеме. Вы можете создавать таблицы в других схемах.
31
\dt information_schema.

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

10

Команда "\ 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)
  • 1
    Это не перечисляет таблицы в схемах кроме public .
7

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

select * from pg_tables where schemaname = 'information_schema'

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

5

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

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

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

1

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

select * from information_schema.tables

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

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

0

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'

Ещё вопросы

Сообщество Overcoder
Наверх
Меню