我有一个具有多个模式的postgres数据库。当我用psql从shell连接到数据库并运行\dt时,它使用默认的公共连接模式。是否有可以指定的标志或如何更改模式?


当前回答

快速解决方案可以是:

SELECT your_db_column_name from "your_db_schema_name"."your_db_tabel_name";

其他回答

\l - Display database
\c - Connect to database
\dn - List schemas
\dt - List tables inside public schemas
\dt schema1. - List tables inside particular schemas. For eg: 'schema1'.

如果你使用PSQL,只需输入

SET schema 'temp';

在此之后,\d显示“temp”中的所有关系

快速解决方案可以是:

SELECT your_db_column_name from "your_db_schema_name"."your_db_tabel_name";

在PostgreSQL中,系统通过遵循搜索路径来确定哪个表,该路径是要查找的模式列表。

搜索路径中的第一个匹配表将被视为需要的表,否则,如果没有匹配则引发错误,即使匹配表名称存在于数据库中的其他模式中。

要显示当前搜索路径,您可以使用以下命令:

SHOW search_path;

要把新的模式放到路径中,你可以使用:

SET search_path TO myschema;

或者如果你想要多个模式:

SET search_path TO myschema, public;

参考:https://www.postgresql.org/docs/current/static/ddl-schemas.html

这是旧的,但我把导出放在我的别名连接到db:

alias schema_one.con="PGOPTIONS='--search_path=schema_one' psql -h host -U user -d database etc"

对于另一个schema:

alias schema_two.con="PGOPTIONS='--search_path=schema_two' psql -h host -U user -d database etc"