正如标题所说,我需要创建一个查询,其中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
如何制定此查询以返回所需的结果?
答案 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