当我使用命名连接到远程服务器或未命名的连接并断开连接时,
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().
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。