如何使用 Postgresql 将行转换为列?

Posted

技术标签:

【中文标题】如何使用 Postgresql 将行转换为列?【英文标题】:How to transform rows to columns using Postgres SQL? 【发布时间】:2019-07-14 01:16:44 【问题描述】:

我有以下结构中的数据

期望的输出

【问题讨论】:

为什么是 mysql 标签? 【参考方案1】:

Postgres(从 9.4 开始)支持条件聚合的 filter 语法。所以我会推荐:

SELECT customer_id,
       MAX(value) FILTER (WHERE name = 'age') as age,
       MAX(value) FILTER (WHERE name = 'marketing_consent') as marketing_consent,
       MAX(value) FILTER (WHERE name = 'gender') as gender
FROM t
GROUP BY customer_id

【讨论】:

【参考方案2】:
SELECT customer_id,
    MAX(CASE WHEN name='age' THEN value ELSE NULL END) AS age,
    MAX(CASE WHEN name='marketing_consent' THEN value ELSE NULL END) AS marketing_consent,
    MAX(CASE WHEN name='gender' THEN value ELSE NULL END) AS gender
FROM table
GROUP BY customer_id;

您只需按 customer_id 分组并在其自己的列中选择每个值。出于语法原因,您需要在各种值列上使用聚合函数,这就是每列都有一个 Max 函数的原因。

请注意,以标准化方式存储数据当然会更好。此外,对于较新版本的 postgres,您可以使用过滤器而不是大小写,我发现它更具可读性。

【讨论】:

以上是关于如何使用 Postgresql 将行转换为列?的主要内容,如果未能解决你的问题,请参考以下文章

BigQuery 标准 SQL 如何将行转换为列

如何根据日期列将行转换为列?

将行转换为列

如何展平 SQL 查询的结果 - 将行转换为列?

Oracle SQL Developer:如何使用 PIVOT 函数将行转置为列

TSQL 将行转换为列