[英]BigQuery - turn columns to array
我有这张桌子:
我正在寻找这张桌子:
我搜索了数组函数 ( array_agg
),但它没有按预期工作。
我该如何处理这个任务? 我必须循环进入此专栏吗?
我的数据集:
SELECT 1 id, 'protoc1' protoc UNION ALL
SELECT 2 id, 'protoc2' protoc UNION ALL
SELECT 3 id, 'protoc3' protoc
不完全确定你为什么想要那个 output,但我注意到你为所有行重复了数组,并且看起来你想要将数组表示为特定的字符串——所以这是我对你的要求的尝试:
with sample as (
SELECT 1 id, 'protoc1' protoc UNION ALL
SELECT 2 id, 'protoc2' protoc UNION ALL
SELECT 3 id, 'protoc3' protoc
), formatted_string as (
select "[" || ARRAY_TO_STRING(ARRAY_AGG(protoc),', ') || "]" as protoc
from sample
)
select sample.id, formatted_string.protoc
from formatted_string
cross join sample
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.