举报投诉联系我们 手机版 热门标签 名动网
您的位置:名动网 > PostgreSQL dblink_connect

PostgreSQL dblink_connect

2023-06-23 15:20

 PostgreSQL dblink_connect

dblink_connect — 打开一个到远程数据库的持久连接

大纲

dblink_connect(text connstr) 返回 text
dblink_connect(text connname, text connstr) 返回 text

描述

dblink_connect()建立一个到远程PostgreSQL数据库的连接。要联系的服务器和数据库通过一个标准的libpq连接串来标识。可以选择将一个名字赋予给该连接。多个命名的连接可以被一次打开,但是一次只允许一个未命名连接。连接将会持续直到被关闭或者数据库会话结束。

连接串也可以是一个现存外部服务器的名字。在使用外部服务器时,我们推荐使用外部数据包装器dblink_fdw。见下面的例子,以及CREATE SERVERCREATE 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;


阅读全文
以上是名动网为你收集整理的 PostgreSQL dblink_connect全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
© 2024 名动网 mdwl.vip 版权所有 联系我们