列出postgresql information_schema中的所有表

在PostgreSQL的information_schema中列出所有表的最好方法是什么?

澄清一下:我正在使用一个空DB(我没有添加任何我自己的表),但我想看到information_schema结构中的每个表。

498658 次浏览

你应该能够运行select * from information_schema.tables来获得Postgres为特定数据库管理的每个表的列表。

你也可以添加where table_schema = 'information_schema'来查看信息模式中的表。

\dt information_schema.

从psql内部,应该没问题。

列出你的表使用:

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

它将只列出您创建的表。

你可以用also

select * from pg_tables where schemaname = 'information_schema'

一般来说,pg* tables允许您查看db中的所有内容,不受您的权限限制(当然,如果您有权限访问这些表)。

对于postgresql中的私有模式'xxx':

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

如果没有table_type = 'BASE TABLE',你将列出表和的观点

“\ 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)

如果你想要一个快速而肮脏的一行查询:

select * from information_schema.tables

您可以直接在查询工具中运行它,而不必打开psql。

(其他帖子建议更具体的information_schema查询,但作为一个新手,我发现这个一行查询可以帮助我掌握表格)

1.从information_schema中获取所有表和视图。表,包括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'