假设我有以下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存储过程?
最佳答案 经过一些工作,我找到了解决这个问题的方法.
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,你.添加苞片时,它将创建一个看起来像这个'(12345,’你’)’的字符串,在Postgres数据库中它将被转换为myType.