首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >查询以获取Postgres中的架构名称

查询以获取Postgres中的架构名称
EN

Stack Overflow用户
提问于 2021-06-23 19:26:54
回答 4查看 56关注 0票数 0

我需要一个逻辑/更清晰的查询来获取我创建的所有模式名称

代码语言:javascript
运行
复制
select schema_name  
from "information_schema"."schemata"

代码语言:javascript
运行
复制
SELECT nspname
FROM pg_catalog.pg_namespace;

返回架构名称的超集,这些架构名称具有系统创建的架构,而我不需要这些架构。

我只需要我创建的模式名称。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2021-06-30 20:34:20

下面的查询解决了我的问题

代码语言:javascript
运行
复制
SELECT distinct pg_namespace.nspname 
FROM pg_catalog.pg_inherits INNER JOIN
pg_catalog.pg_class ON (pg_inherits.inhrelid = pg_class.oid) INNER JOIN
pg_catalog.pg_namespace ON (pg_class.relnamespace = pg_namespace.oid)
WHERE pg_namespace.nspname <> 'public';
票数 0
EN

Stack Overflow用户

发布于 2021-06-23 19:40:04

尝试从information_schema.schemata过滤pg_*模式和information_schema本身:

代码语言:javascript
运行
复制
SELECT * from information_schema.schemata 
WHERE NOT schema_name LIKE 'pg_%' AND schema_name <> 'information_schema'

按照戈登的建议,排除postgres拥有的模式只适用于这样的条件:postgres不是任何其他模式的所有者,而是系统模式的所有者。如果您使用用户postgres创建了一个模式,那么它将被排除在结果集中。

票数 1
EN

Stack Overflow用户

发布于 2021-06-23 19:30:03

如果您不需要内置的模式,那么可以使用:

代码语言:javascript
运行
复制
select schema_name
from "information_schema"."schemata"
where schema_owner <> 'postgres';

如果你想要你特别创建的那些,那么检查一下你是所有者的那些。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68098939

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档