首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >即使扩展已经存在,dblink也不存在?

即使扩展已经存在,dblink也不存在?
EN

Stack Overflow用户
提问于 2017-10-04 05:12:44
回答 1查看 4.3K关注 0票数 8

所以我刚开始使用dblink,我刚刚创建了一个脚本,将数据插入到另一个数据库的表中。我收到了错误function dblink(unknown,unknown) does not exist

所以我上网查了一下,用了CREATE EXTENSION dblink,最后得到了这条消息extension "dblink" already exists

我的dblink代码如下所示:

代码语言:javascript
运行
复制
INSERT INTO tableA
 SELECT tbl.colA,tbl.colB,...
 FROM dblink('dbname=anotherDB', 'SELECT colA,colB,...
                 FROM tableB')
as tbl(colA,colB,...)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-10-04 06:10:39

检查在哪个架构中安装了扩展。在我的例子中,这个模式是ext

代码语言:javascript
运行
复制
select nspname as schema
from pg_extension e
join pg_namespace n on n.oid = e.extnamespace
where extname = 'dblink'

 schema 
--------
 ext
(1 row) 

将模式名称添加到搜索路径,例如:

代码语言:javascript
运行
复制
set search_path to public, ext;

或者使用函数dblink()的限定名,例如:

代码语言:javascript
运行
复制
INSERT INTO tableA
 SELECT tbl.colA,tbl.colB,...
 FROM ext.dblink('dbname=anotherDB', 'SELECT colA,colB,...
                 FROM tableB')
as tbl(colA,colB,...)
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46557439

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档