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存储过程?
经过更多工作后,我找到了这个问题的解决方案。
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.
| 归档时间: |
|
| 查看次数: |
555 次 |
| 最近记录: |