我正在尝试在其参数中使用ParameterizedQuery带有SQL 名称的 a。text
我知道文档读到此参数必须是 astring或 a QueryFile。
基本上,我想做的是:
import pgPromise from 'pg-promise';
const pgp = pgPromise();
const pq = new pgp.ParameterizedQuery({
text: `
SELECT $1:name from my_table
where $2:name = $3;
`,
rowMode: 'array'
});
const params = {user_col: 'user', id_col: 'id', id_value: 'XXX'};
try {
return await this.db.any(pq, Object.values(params));
} catch (e) {
console.error(e);
return e;
}
我得到的是一个错误,如:
QUERY: {
[start:run] text: '\n' +
[start:run] ' SELECT $1:name from my_table\n' +
[start:run] ' where $2:name = $3;\n' +
[start:run] ' ',
[start:run] values: [ 'user', 'id', 'XXX' ],
[start:run] rowMode: 'array'
[start:run] }
[start:run] error: syntax error at or near ":"
是否可以在 a 中使用:name(或~)ParameterizedQuery?问题是,我真的希望我的查询结果是一个行数组而不是行对象数组,而 ParameterizedQuery 的参数rowMode设置array似乎是我能做到这一点的唯一方法。