dblink_connect — 打开到远程数据库的持久连接
dblink_connect(text connstr) 返回 text dblink_connect(text connname, text connstr) 返回 text
dblink_connect() 建立到远程 PostgreSQL 数据库的连接。要联系的服务器和数据库通过标准的 libpq 连接字符串标识。可以为该连接指定一个名称。 可同时打开多个命名连接,但同一时间只允许存在一个未命名连接。该连接会一直保留到被关闭或数据库会话结束。
连接字符串也可以是现有外部服务器的名称。定义该外部服务器时,建议使用外部数据包装器 dblink_fdw。请参见下面的示例,以及 CREATE SERVER 和 CREATE USER MAPPING。
connname #用于该连接的名称;如果省略,则打开一个未命名连接,并替换现有的未命名连接。
connstr #libpq-风格的连接信息字符串,例如 hostaddr=127.0.0.1 port=5432 dbname=mydb user=postgres password=mypasswd options=-csearch_path=。 详见Section 32.1.1。 此外,也可以是外部服务器的名称。
返回状态,总是 OK(因为任何错误都会导致该函数抛出错误,而不是返回)。
如果不可信用户能够访问一个尚未采用安全的模式使用方式的数据库,则应在每个会话开始时从 search_path 中移除公共可写模式。例如,可以把 options=-csearch_path= 加到 connstr 中。这个注意事项并非 dblink 所特有;它适用于每一种执行任意 SQL 命令的接口。
外部数据包装器 dblink_fdw 还有一个额外的布尔选项 use_scram_passthrough,用于控制 dblink 是否在连接远程数据库时使用 SCRAM 透传认证。 使用 SCRAM 透传认证时,dblink 会使用 SCRAM 哈希后的凭据,而不是明文用户密码来连接远程服务器。 这样可以避免在 PostgreSQL 系统目录中存储明文用户密码。关于更多细节和限制,请参见 postgres_fdw 中对应的 use_scram_passthrough 选项文档。
只有超级用户才能使用 dblink_connect 创建不使用密码认证的连接。 如果非超级用户需要这种能力,请改用 dblink_connect_u。
选择包含等号的连接名称并不明智,因为这会导致在其他 dblink 函数中与连接信息字符串产生混淆风险。
SELECT dblink_connect('dbname=postgres options=-csearch_path=');
dblink_connect
----------------
OK
(1 row)
SELECT dblink_connect('myconn', 'dbname=postgres options=-csearch_path=');
dblink_connect
----------------
OK
(1 row)
-- FOREIGN DATA WRAPPER functionality
-- Note: local connections that don't use SCRAM pass-through require password
-- authentication for this to work properly. Otherwise, you will receive
-- the following error from dblink_connect():
-- ERROR: password is required
-- DETAIL: Non-superuser cannot connect if the server does not request a password.
-- HINT: Target server's authentication method must be changed.
CREATE SERVER fdtest FOREIGN DATA WRAPPER dblink_fdw OPTIONS (hostaddr '127.0.0.1', dbname 'contrib_regression');
CREATE USER regress_dblink_user WITH PASSWORD 'secret';
CREATE USER MAPPING FOR regress_dblink_user SERVER fdtest OPTIONS (user 'regress_dblink_user', password 'secret');
GRANT USAGE ON FOREIGN SERVER fdtest TO regress_dblink_user;
GRANT SELECT ON TABLE foo TO regress_dblink_user;
\set ORIGINAL_USER :USER
\c - regress_dblink_user
SELECT dblink_connect('myconn', 'fdtest');
dblink_connect
----------------
OK
(1 row)
SELECT * FROM dblink('myconn', 'SELECT * FROM foo') AS t(a int, b text, c text[]);
a | b | c
----+---+---------------
0 | a | {a0,b0,c0}
1 | b | {a1,b1,c1}
2 | c | {a2,b2,c2}
3 | d | {a3,b3,c3}
4 | e | {a4,b4,c4}
5 | f | {a5,b5,c5}
6 | g | {a6,b6,c6}
7 | h | {a7,b7,c7}
8 | i | {a8,b8,c8}
9 | j | {a9,b9,c9}
10 | k | {a10,b10,c10}
(11 rows)
\c - :ORIGINAL_USER
REVOKE USAGE ON FOREIGN SERVER fdtest FROM regress_dblink_user;
REVOKE SELECT ON TABLE foo FROM regress_dblink_user;
DROP USER MAPPING FOR regress_dblink_user SERVER fdtest;
DROP USER regress_dblink_user;
DROP SERVER fdtest;
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。