Postgresql在子查询中使用多行作为表达式

时间:2018-01-25 06:24:13

标签: postgresql subquery pivot postgresql-9.1 crosstab

正如标题所说,我需要创建一个查询,其中SELECT来自一个表的所有项目,并将这些项目用作另一个查询中的表达式。假设我有一个如下所示的主表:

main_table
-------------------------------------
id | name | location | //more columns
---|------|----------|---------------
 1 | me   | pluto    | //
 2 | them | mercury  | //
 3 | we   | jupiter  | //

子查询表如下所示:

some_table
---------------
id | item
---|-----------
 1 | sub-col-1
 2 | sub-col-2
 3 | sub-col-3

some_table中的每个项目的价格都是amount_table,如此:

amount_table
--------------
 1 | 1000
 2 | 2000
 3 | 3000

以便查询返回如下结果:

name | location | sub-col-1 | sub-col-2 | sub-col-3 |
----------------------------------------------------|
me   | pluto    | 1000      |           |           |
them | mercury  |           | 2000      |           |
we   | jupiter  |           |           | 3000      |

我的查询目前看起来像这样

SELECT name, location, (SELECT item FROM some_table)
FROM main_table
INNER JOIN amount_table WHERE //match the id's

但我遇到了错误more than one row returned by a subquery used as an expression

如何制定此查询以返回所需的结果?

1 个答案:

答案 0 :(得分:1)

你应该决定预期的结果。

获得一对多关系:

SELECT name, location, some_table.item
FROM main_table
JOIN some_table on true -- or id if they match
INNER JOIN amount_table --WHERE match the id's

与所有行一对一:

SELECT name, location, (SELECT array_agg(item) FROM some_table)
FROM main_table
INNER JOIN amount_table --WHERE //match the id's