PostgreSQL 8.4中是否有一种方法可以使用表单元格内容作为结果中的列名(例如,作为别名)



我有一个一对多的关系。我有三张桌子:

|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不允许像上面所写的那样使用列引用作为列别名。它不是有效的语法,而且要使它工作会有一些逻辑问题。

相关内容

  • 没有找到相关文章

最新更新