PostgreSQL中的复合类型在node-postgres上的应用

6

假设我有以下的PostgreSQL复合类型:

CREATE TYPE myType AS(
  id  bigint,
  name  text,
);

还需要一个接受该类型的存储过程:

CREATE FUNCTION myFunction(mt myType){
//do some stuff
}

我希望使用node-postgres模块从Node-js调用这个过程。

var pg = require('pg');
var connectionString = "connection string";
pg.connect(connectionString, function(err, client, done) {
   client.query('SELECT myFunction($1)', [some value],   
      function(err, result) {
      // do stuff
      done();
    });
});

我该如何在JS中创建这样的类型?有没有办法将类型从Node传递到Postgres存储过程中?

2个回答

4

经过进一步的工作,我找到了解决这个问题的方案。

var pg = require('pg');
var connectionString = "connection string";

var myType = [
  12345,
  'you'
];
pg.connect(connectionString, function(err, client, done) {
   client.query('SELECT myFunction($1::myType)', 
     ['(' + myType.join(',') + ')' ],   
     function(err, result) {
      // do stuff
    done();
   });
});

该联接将返回:12345,you。添加大括号后,将创建一个字符串,看起来像这样:'(12345,'you')',在Postgres数据库中,它将被转换为myType

1
好问题。我写了一个类似的例子要发布,但看到了你的问题,就全都明白了。 - Nulik

0
如果您正在寻找将数据组合在一起传递的另一个潜在解决方案,请考虑使用json。由于json在Javascript(以及许多其他语言)中很容易处理,因此处理起来非常简单。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接