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 存储过程?

4

2 回答 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 DB 中它会被转换为myType.

于 2015-03-30T12:26:13.847 回答
0

如果您正在寻找另一种可能的解决方案来解决传递类型组合数据的问题,请考虑使用 json。由于 json 在 Javascript(和许多其他语言)中很容易处理,因此很容易处理。

于 2021-02-25T22:46:25.517 回答