首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用pg的dblink扩展

使用pg的dblink扩展
EN

Stack Overflow用户
提问于 2022-02-03 15:15:49
回答 1查看 260关注 0票数 0

我有一个带有dblink扩展的PostgreSQL数据库。我可以使用dblink而不受pgAdmin的影响,但不能使用pg承诺从我的nodeJS代码中使用。

我已经检查了我在正确的模式和数据库上。从我的代码中运行SELECT * FROM pg_extension;确实会返回安装了dblink。但是,在:error: function dblink(unknown, unknown) does not exist中运行包含dblink结果的查询

在这种情况下,我应该做些什么来使dblink工作吗?

这是我的代码的一个基本示例:

代码语言:javascript
复制
query1 = 'SELECT * FROM pg_extension;'
query2 = `Select *
     FROM dblink('host=XXX user=XXX password=XXXX dbname=XXXX',
    'select name from example_table')
    AS t(name text);`

db.any(
 query1
).then(function(results) {
 console.log('Query1 result:', results)
}).catch(function(err) {
 console.log(`Error in query1 ${err}`)
})

db.any(
  query2
).then(function(results) {
  console.log('Query2 result:', results)
}).catch(function(err) {
  console.log(`Error in query2 ${err}`)
})  

结果:

代码语言:javascript
复制
Query1 result: [
  {
    extname: 'plpgsql',
    extowner: 10,
    extnamespace: 11,
    extrelocatable: false,
    extversion: '1.0',
    extconfig: null,
    extcondition: null
  },
  {
    extname: 'dblink',
    extowner: 10,
    extnamespace: 2200,
    extrelocatable: true,
    extversion: '1.2',
    extconfig: null,
    extcondition: null
  },
  {
    extname: 'timescaledb',
    extowner: 10,
    extnamespace: 24523,
    extrelocatable: false,
    extversion: '1.7.1',
    extconfig: [
      25044, 25042, 25068, 25083,
      25081, 25102, 25100, 25118,
      25116, 25139, 25155, 25157,
      25173, 25175, 25193, 25210,
      25246, 25254, 25283, 25293,
      25303, 25307, 25324, 25343,
      25358, 25472, 25478, 25475
    ],
    extcondition: [
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      'WHERE id >= 1000',
      '',
      '',
      "WHERE key='exported_uuid'",
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      '',
      ''
    ]
  }
]
Error in query2 error: function dblink(unknown, unknown) does not exist
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-03 17:50:31

如果dblink安装在"public“中,但"public”不在我的search_path中,那么它就像我得到的结果。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70973782

复制
相关文章

相似问题

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