PostgreSQL - 查询表结构和索引信息

前言

PostgreSQL的表一般都是建立在public这个schema下的,假如现在有个数据表t_student,可以用以下几种方式来查询表结构和索引信息。

使用\d元命令查看表字段信息和索引信息

cmd界面使用psql连接db后,输入\d加上表名即可:

`\d t_student` 

通过系统数据字典查询表结构

`select
col.table_schema,
col.table_name,
col.ordinal_position,
col.column_name,
col.data_type,
col.character_maximum_length,
col.numeric_precision,
col.numeric_scale,
col.is_nullable,
col.column_default,
des.description
from
information_schema.columns col left join pg_description des on
col.table_name::regclass = des.objoid
and col.ordinal_position = des.objsubid
where
table_schema = 'public'
and table_name = 't_student'
order by
ordinal_position;`


或者简单点:

`select * from information_schema.columns
where table_schema='public' and table_name='t_student';`


通过系统数据字典查询索引信息

`select
A.SCHEMANAME,
A.TABLENAME,
A.INDEXNAME,
A.TABLESPACE,
A.INDEXDEF,
B.AMNAME,
C.INDEXRELID,
C.INDNATTS,
C.INDISUNIQUE,
C.INDISPRIMARY,
C.INDISCLUSTERED,
D.DESCRIPTION
from
PG_AM B left join PG_CLASS F on
B.OID = F.RELAM left join PG_STAT_ALL_INDEXES E on
F.OID = E.INDEXRELID left join PG_INDEX C on
E.INDEXRELID = C.INDEXRELID left outer join PG_DESCRIPTION D on
C.INDEXRELID = D.OBJOID,
PG_INDEXES A
where
A.SCHEMANAME = E.SCHEMANAME
and A.TABLENAME = E.RELNAME
and A.INDEXNAME = E.INDEXRELNAME
and E.SCHEMANAME = 'public'
and E.RELNAME = 't_student';`

查询所有的表名

`select
n.nspname,
relname
from
pg_class c,
pg_namespace n
where
c.relnamespace = n.oid
and nspname = 'public'
and relkind = 'r'
order by
relname;`

可视化工具DBeaver

对于上述的sql语句只需要修改要查询的table name,可以根据需要自行修改想要查询的column。如果是通过DBeaver来连接数据库,还可以直接在当前的数据库实例下打开schema里的public选项,接着选中table,选中你想查看的表,可以很直观地看到该表的各种信息:column、index等等。

参考链接

文章知识点与官方知识档案匹配,可进一步学习相关知识

PostgreSQL技能树查询数据psql

雨临Lewis

码龄5年 暂无认证

195
原创

1万+
周排名

133万+
总排名

151万+

访问

等级

1万+

积分

437

粉丝

447

获赞

209

评论

1113

收藏

私信

关注

文心雕龙

☞ My Blog

Github ☜

/***
* ,%%%%%%%%,
* ,%%/\%%%%/\%%
* ,%%%\c "" J/%%%
* %. %%%%/ o o \%%%
* `%%. %%%% _ |%%%
* `%% `%%%%(__Y__)%%'
* // ;%%%%`\-/%%%'
* (( / `%%%%%%%'
* \\ .' |
* \\ / \ | |
* \\/ ) | |
* \ /_ | |__
* (___________)))))))
* -------------攻城狮--------------
*/

热门文章

分类专栏

最新评论

您愿意向朋友推荐“博客详情页”吗?

  • 强烈不推荐
  • 不推荐
  • 一般般
  • 推荐
  • 强烈推荐

最新文章

2020年1篇

2019年42篇

2018年113篇

2017年79篇

目录

  1. 前言
  2. 使用\d元命令查看表字段信息和索引信息
  3. 通过系统数据字典查询表结构
  4. 通过系统数据字典查询索引信息
  5. 查询所有的表名
  6. 可视化工具DBeaver
  7. 参考链接

举报

×

拖拽到此处

图片将完成下载