加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL dblink与命名连接

发布时间:2020-12-13 16:08:40 所属栏目:百科 来源:网络整理
导读:当我使用命名连接到远程服务器或未命名的连接并断开连接时, dblink 似乎不起作用.如果我在dblink()中使用带有连接字符串的未命名连接,它可以正常工作.它似乎连接正常,但我尝试使用它时我的连接不可用.关于如何使用命名连接的任何想法? 未提及connstr工作正
当我使用命名连接到远程服务器或未命名的连接并断开连接时,dblink似乎不起作用.如果我在dblink()中使用带有连接字符串的未命名连接,它可以正常工作.它似乎连接正常,但我尝试使用它时我的连接不可用.关于如何使用命名连接的任何想法?

未提及connstr工作正常:

SELECT testtable.*
FROM   dblink('dbname=testdb port=5432 host=192.168.1.1 user=usr password=pw','SELECT * FROM testtable')
AS     testtable(testtable_id integer,testtable_name text);

返回:按预期方式返回两列.

命名不起作用:

连接:

SELECT dblink_connect('myconn','dbname=testdb port=5432 host=192.168.1.1 user=usr password=pw');

返回:“OK”

查询:

SELECT testtable.* FROM dblink('myconn',testtable_name text);

返回:

ERROR:  could not establish connection
DETAIL:  missing "=" after "myconn" in connection info string

********** Error **********

ERROR: could not establish connection
SQL state: 08001
Detail: missing "=" after "myconn" in connection info string

断开:

SELECT dblink_disconnect('myconn');

返回:

ERROR:  connection "myconn" not available

********** Error **********

ERROR: connection "myconn" not available
SQL state: 08003

未命名_connect和_disconnect不起作用:

连接:

SELECT dblink_connect('dbname=testdb port=5432 host=192.168.1.1
                                               user=usr password=pw');

返回:“OK”

查询:

SELECT testtable.* FROM dblink('SELECT * FROM testtable')
AS testtable(testtable_id integer,testtable_name text);

返回:

ERROR:  connection not available

********** Error **********

ERROR: connection not available
SQL state: 08003

断开:

SELECT dblink_disconnect();

返回:

ERROR:  connection not available

********** Error **********

ERROR: connection not available
SQL state: 08003

解决方法

我有一个使用未命名连接的工作设置.

你在问题中称之为“未命名”,实际上有一个名称参数.你在混淆这两个变种.试试没有’myconn’:

SELECT *
FROM   dblink('SELECT * FROM testtable'
        ) AS testtable (testtable_id integer,testtable_name text);

请记住,建立连接并使用它必须在同一个会话中进行.

但老实说,我找不到你的命名连接有什么问题.我做了一些测试,一切看起来都正确.我用PostgreSQL 9.1测试过.

该错误消息暗示dblink期望connstr.只有当第一个参数与现有的任何connname都不匹配时才会发生这种情况简而言之:找不到连接’myconn’ – 这让我怀疑你没有在与dblink_connect()相同的会话中调用dblink().

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读