千家信息网

加入三行,如果一列中相同的值

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,有一个Postgres数据库和表有三个列。 数据结构在外部系统所以我不能修改它。每个对象由三行(被列element_id--行相同的值在本专栏中代表同一个对象),例如:key value
千家信息网最后更新 2025年01月22日加入三行,如果一列中相同的值

有一个Postgres数据库和表有三个列。 数据结构在外部系统所以我不能修改它。

每个对象由三行(被列element_id--行相同的值在本专栏中代表同一个对象),例如:

key     value            element_id-----------------------------------status  active           1name    exampleNameAAA   1city    exampleCityAAA   1status  inactive         2name    exampleNameBBB   2city    exampleCityBBB   2status  inactive         3name    exampleNameCCC   3city    exampleCityCCC   3

我想要所有的值描述每个对象(名称、状态和城市)。

对于这个示例的输出应该是:

exampleNameAAA   | active    | exampleCityAAAexampleNameBBB   | inactive  | exampleCityBBBexampleNameCCC   | inactive  | exampleCityCCC

我知道如何加入两行:

select a.value as name,       b.value as statusfrom the_table a   join the_table b     on a.element_id = b.element_id    and b."key" = 'status'where a."key" = 'name';

怎么可能加入三列?


0