postgres SELECT查询返回无法使用的结果

问题描述 投票:0回答:2

我有一个简单的SELECT查询,返回的结果不可用。我在node.js中使用pg-promise

[
  {
    "function_name": "(f10d1988-4db5-49de-97ab-0c8b15bedfa7,image.jpg,Image)"
  },
  {
    "function_name": "(f10d1988-4db5-49de-97ab-0c8b15bedfa7,image2.jpg,Image 2)"
  }
]

但是我期待一个基本的json结构,如

[
  {
    id: '',
    title: '',
    image: ''
  },
  {...etc}
]

为什么这么做?如何获得标准化结果?

我的查询如下所示:

CREATE OR REPLACE FUNCTION get_photos(
  title_param     TEXT
)
RETURNS TABLE(
  id         UUID,
  image      varchar(200),
  title      varchar(200) 
) AS
$func$
BEGIN
  RETURN QUERY SELECT
    i.id,
    i.image,
    i.title
  FROM images AS i
  WHERE i.title = title_param;
END;
$func$ LANGUAGE PLPGSQL;

这是我的数据库连接器设置,几乎所有默认设置。

require('dotenv').config();
const Promise = require('bluebird');
const pg = require('pg-promise')({
  promiseLib: Promise
});

const config = {
  user: process.env.USER,
  host: process.env.HOST,
  database: process.env.DATABASE,
  password: process.env.PASSWORD
};

const db = pg(config);

export default db;

这里是正在调用该函数的明确端点:

export const getData = async (req, res) => {
  const { title } = req.query;
  let data;
  try {
    data = await db.many('SELECT function_name($1)', [title]);
  } catch (err) {
    data = err;
  }
  res.send(data);
};

编辑

我手动而不是通过函数运行查询,并且正确返回了数据,这意味着TABLE()返回存在问题。什么可能导致此问题?

images = await db.many(`
  SELECT
    p.id,
    p.img,
    p.type,
    p.title
  FROM photos p
  WHERE p.type = '${type}';
`, [type]);
node.js json postgresql select pg-promise
2个回答
2
投票

由于该函数被定义为返回表,因此您需要像表一样使用它:

SELECT * FROM function_name($1)

0
投票

使用func作为查询方法:

data = await db.func('function_name', [title]);

假定您返回了一个表,因此默认情况下将为您工作。

对于存储过程,有proc方法。


此外,您用于图像查询的参数格式错误,请参见Named Parameters

重要:切勿在ES6模板字符串中使用保留的${}语法...

© www.soinside.com 2019 - 2024. All rights reserved.