我需要一个逻辑/更清晰的查询来获取我创建的所有模式名称
select schema_name
from "information_schema"."schemata"和
SELECT nspname
FROM pg_catalog.pg_namespace;返回架构名称的超集,这些架构名称具有系统创建的架构,而我不需要这些架构。
我只需要我创建的模式名称。
发布于 2021-06-30 20:34:20
下面的查询解决了我的问题
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';发布于 2021-06-23 19:40:04
尝试从information_schema.schemata过滤pg_*模式和information_schema本身:
SELECT * from information_schema.schemata
WHERE NOT schema_name LIKE 'pg_%' AND schema_name <> 'information_schema'按照戈登的建议,排除postgres拥有的模式只适用于这样的条件:postgres不是任何其他模式的所有者,而是系统模式的所有者。如果您使用用户postgres创建了一个模式,那么它将被排除在结果集中。
发布于 2021-06-23 19:30:03
如果您不需要内置的模式,那么可以使用:
select schema_name
from "information_schema"."schemata"
where schema_owner <> 'postgres';如果你想要你特别创建的那些,那么检查一下你是所有者的那些。
https://stackoverflow.com/questions/68098939
复制相似问题