SQL将行变成雪花中的列

Posted

技术标签:

【中文标题】SQL将行变成雪花中的列【英文标题】:SQL to turn rows into column in snowflake 【发布时间】:2021-03-31 22:52:07 【问题描述】:

我在雪花中有一张桌子,如下所示:

有人可以帮我解决这个问题吗?

【问题讨论】:

Google 的“SQL 数据透视查询” 【参考方案1】:

使用 pivot() 非常简单:

select
*
from
yourtable
pivot(sum(page_view) for "Topic" in ('COLLEGE_SPORTS_OTHER', 'ENTERTAINMENT', 'LOCAL') )
as p

雪花文档:https://docs.snowflake.com/en/sql-reference/constructs/pivot.html

【讨论】:

【参考方案2】:

您可以使用条件聚合:

select account_id,
    sum(case when topic = 'COLLEGE_SPORTS_OTHER' then page_view else 0 end) as cnt_college,
    sum(case when topic = 'ENTERTAINMENT'        then page_view else 0 end) as cnt_entertainment,
    sum(case when topic = 'LOCAL'                then page_view else 0 end) as cnt_local
from mytable
group by account_id

【讨论】:

以上是关于SQL将行变成雪花中的列的主要内容,如果未能解决你的问题,请参考以下文章

雪花,获取两个表之间不匹配列的列表(SQL)

预计将解析从 S3 加载的雪花数据中的列时到达记录末尾

根据雪花中的条件选择列

在 Python 上使用 Azure 函数的雪花外部函数不起作用

检查雪花中的表架构更改

雪花中的Bytea替代品是啥