gpt4 book ai didi

postgresql - 为什么 postgres_fdw 是双重限定模式?

转载 作者:行者123 更新时间:2023-11-29 12:46:09 25 4
gpt4 key购买 nike

使用 postgres_fdw,我需要在指定模式中创建外部表以防止名称冲突。为了隔离我一直遇到的问题,我在同一集群上设置了两个测试 postgres 数据库,import_test 和 export_test。 Export_test 有一个表,foreign_schema.aa。在服务器 import_test 上,完成其他 FDW 先决条件后,我运行:

CREATE FOREIGN TABLE local_schema.aa(
id serial NOT NULL,
dat text
) SERVER export_server OPTIONS (table_name 'foreign_schema.aa');

然后:

SELECT * FROM local_schema.aa;

当我这样做时,我得到:

ERROR:  relation "local_schema.foreign_schema.aa" does not exist
CONTEXT: Remote SQL command: SELECT id, dat FROM local_schema."foreign_schema.aa"

如果我不做任何模式限定,如:

CREATE FOREIGN TABLE aa(
id serial NOT NULL,
dat text
) SERVER export_server OPTIONS (table_name 'aa');

并将 aa 表移动到公共(public)模式,选择工作正常。

如果“SELECT id, dat FROM local_schema.”远程服务器。出于某种原因,postgres_fdw 似乎在为 table_name 提供的名称前面加上外部表的模式。

我需要在选择查询中指定架构,因为如果我不这样做,它就看不到外部表。通过在选择之前设置搜索路径来实现模式限定也无济于事。

我做错了什么吗?如果没有,是否有一种解决方法可以让我对外表进行架构限定?

编辑:根据@Craig Ringer 的建议,这里是独立的 psql 输入:

CREATE USER test_user SUPERUSER PASSWORD 'password';
SET ROLE test_user;
CREATE DATABASE import;
CREATE DATABASE export;
\c export test_user
CREATE SCHEMA export_schema;
CREATE TABLE export_schema.aa (
id serial PRIMARY KEY,
dat text
);
\c import test_user
CREATE EXTENSION postgres_fdw;
CREATE SERVER export_server
FOREIGN DATA WRAPPER postgres_fdw
OPTIONS (host 'localhost', dbname 'export', port '5432');
CREATE USER MAPPING FOR test_user
SERVER export_server
OPTIONS (user 'test_user', password 'password');
CREATE SCHEMA import_schema;
CREATE FOREIGN TABLE import_schema.aa(
id serial NOT NULL,
dat text
) SERVER export_server OPTIONS (table_name 'export_schema.aa');
SELECT * FROM import_schema.aa;

产生这个输出:

ERROR:  relation "import_schema.export_schema.aa" does not exist
CONTEXT: Remote SQL command: SELECT id, dat FROM import_schema."export_schema.aa"

最佳答案

忘记带着决议回来了。原来在我发布错误报告的某个时候,postgres_fdw 上的文档已更新。请参阅“F.31.1.2. 对象名称选项”部分和此页面上的 schema_name 选项:http://www.postgresql.org/docs/current/static/postgres-fdw.html .我引用邮件列表回复:

 "Use: OPTIONS (schema_name 'export_schema', table_name 'aa'); above.

Thanks,

Stephen"

因此要解决,只需在 schema_name 选项参数中指定外部模式名称即可。

关于postgresql - 为什么 postgres_fdw 是双重限定模式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21193642/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com