node-postgres上的postgres复合类型

Yak*_*ein 5 postgresql node.js node-postgres

说我有以下postgreSQL复合类型:

CREATE TYPE myType AS(
  id  bigint,
  name  text,
);
Run Code Online (Sandbox Code Playgroud)

以及除该类型外的存储过程:

CREATE FUNCTION myFunction(mt myType){
//do some stuff
}
Run Code Online (Sandbox Code Playgroud)

我想使用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();
    });
});
Run Code Online (Sandbox Code Playgroud)

如何在JS中创建这样的类型?有没有一种方法可以将类型从Node传递到Postgres存储过程?

Yak*_*ein 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();
   });
});
Run Code Online (Sandbox Code Playgroud)

连接将返回:12345,you。添加花括号时,它将创建一个如下所示的字符串'(12345,'you')',在 Postgres DB 中它将被转换为myType.