Каков наилучший способ перечислить все таблицы в PostgreSQL information_schema?
Чтобы уточнить: я работаю с пустой БД (я не добавил ни одной из моих собственных таблиц), но я хочу видеть каждую таблицу в структуре information_schema.
Каков наилучший способ перечислить все таблицы в PostgreSQL information_schema?
Чтобы уточнить: я работаю с пустой БД (я не добавил ни одной из моих собственных таблиц), но я хочу видеть каждую таблицу в структуре information_schema.
Вы можете просто запустить select * from information_schema.tables
, чтобы получить список каждой таблицы, управляемой Postgres для конкретной базы данных.
Вы также можете добавить where table_schema = 'information_schema'
, чтобы видеть только таблицы в информационной схеме.
Для перечисления ваших таблиц используйте:
SELECT table_name FROM information_schema.tables WHERE table_schema='public'
Он отображает только список создаваемых таблиц.
\dt information_schema.
из psql, должно быть хорошо.
Команда "\ 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)
Вы также можете использовать
select * from pg_tables where schemaname = 'information_schema'
В общих таблицах pg * вы можете видеть все в db, не ограничиваясь вашими разрешениями (если у вас есть доступ к таблицам, конечно).
Для частной схемы 'xxx'
в postgresql:
SELECT table_name FROM information_schema.tables
WHERE table_schema = 'xxx' AND table_type = 'BASE TABLE'
Без table_type = 'BASE TABLE'
вы перечислите таблицы и виды
Если вам нужен быстрый и грязный однострочный запрос:
select * from information_schema.tables
Вы можете запустить его непосредственно в инструменте Query без необходимости открывать psql.
(Другие сообщения предлагают интересные более конкретные запросы information_schema, но как newby, я нахожу, что этот однострочный запрос помогает мне справиться с таблицей)
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'