1

我正在尝试在其参数中使用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似乎是我能做到这一点的唯一方法。

4

1 回答 1

1

格式化过滤器文档:

请注意,格式化过滤器仅适用于普通查询,并且在PreparedStatementParameterizedQuery中不可用,因为根据定义,它们是在服务器端格式化的。

官方文档中的那条注释是在这个问题之后添加的,因为它之前出现过几次。希望从现在开始会更清楚。

于 2020-09-03T22:40:37.833 回答