dblink_connect
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
。详见第 33.1.1 节。此外,还可以是一个外部服务器的名字。
返回值
返回状态,它总是OK
(因为任何错误会导致该函数抛出一个错误而不是返回)。
注解
如果不可信用户能够访问一个没有采用安全方案使用模式的数据库,应该在开始每个会话时从search_path
中移除公共可写的方案。例如,可以把options=-csearch_path=
增加到connstr
。这种考虑不是特别针对dblink
,它适用于每一种执行任意SQL命令的接口。
只有超级用户能够使用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 connection must 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;