我有一个一对多的关系。我有三张桌子:
|A | | B | |C |
|ID| ... | |ID|A_ID|C_ID|VALUE| |ID|NAME|
|1 | | |1 |1 |2 |val_1| |1 |a |
|2 | | |2 |1 |1 |val_2| |2 |b |
|3 | | |3 |2 |1 |first| |
...
我需要得到一个结果表:
|ID|a |b |
|1 |val_2|val_1|
|2 |NULL |NULL |
|3 |first|NULL |
即,第一列是A.ID,其他列是来自B的VALUE列,但这些列的名称是来自C.的NAME
我的一个想法是查询
SELECT A.ID, B.VALUE AS C.NAME FROM A, B, C WHERE B.A_ID = A.ID AND B.C_ID = C.ID
但我有:
ERROR: syntax error at or near "."
有人知道如何解决PostgreSQL 8.4中一个查询的问题吗?
看起来您想要一个"交叉表"或"透视表"查询。请参阅tablefunc模块中的一些函数,并在Stack Overflow中搜索[postgresql] crosstab
或[postgresql] pivot
。
SQL不允许像上面所写的那样使用列引用作为列别名。它不是有效的语法,而且要使它工作会有一些逻辑问题。