雪花中是否有融化命令?

时间:2021-07-28 00:40:22

标签: sql snowflake-cloud-data-platform unpivot melt

是否有一个 Snowflake 命令可以像这样转换表格:

a,b,c
1,10,0.1
2,11,0.12
3,12,0.13

到这样的表:

key,value
a,1
a,2
a,3
b,10
b,11
b,13
c,0.1
c,0.12
c,0.13

此操作在其他表格系统中常称为melt,但基本思想是将表格转换为键值对列表。

SnowSQL 中有一个 UNPIVOT,但据我所知,UNPIVOT 需要手动指定每一列。这对于大量列来说似乎不太实用。

1 个答案:

答案 0 :(得分:3)

Snowflake 的 SQL 功能强大,无需借助第三方工具或其他扩展程序即可执行此类操作。

数据准备:

CREATE OR REPLACE TABLE t(a INT, b INT, c DECIMAL(10,2))
AS
SELECT 1,10,0.1
UNION SELECT 2,11,0.12
UNION SELECT 3,12,0.13;

enter image description here

查询(又名“动态”UNPIVOT):

SELECT f.KEY, f.VALUE
FROM (SELECT OBJECT_CONSTRUCT_KEEP_NULL(*) AS j FROM t) AS s
,TABLE(FLATTEN(input => s.j)) f
ORDER BY f.KEY;

输出:

enter image description here


它是如何工作的?

  1. 将行转换为 JSON(第 1 行变为 { "A": 1,"B": 10,"C": 0.1 }
  2. 使用 FLATTEN 将 JSON 解析为键值对