BigQuery - 将列转换为数组
BigQuery - turn columns to array
我有这个table:
我正在寻找这个 table:
我搜索了数组函数 (array_agg
),但没有按预期工作。
我该如何处理这个任务?我必须循环进入此专栏吗?
我的数据集:
SELECT 1 id, 'protoc1' protoc UNION ALL
SELECT 2 id, 'protoc2' protoc UNION ALL
SELECT 3 id, 'protoc3' protoc
不确定您为什么需要该输出,但我注意到您为所有行重复了数组,看起来您希望将数组表示为特定字符串——所以这是我对您所问内容的尝试:
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
下面使用
select id, format('%t', array_agg(protoc) over()) protoc
from your_table
如果应用于您问题中的示例数据 - 输出为
我有这个table:
我正在寻找这个 table:
我搜索了数组函数 (array_agg
),但没有按预期工作。
我该如何处理这个任务?我必须循环进入此专栏吗?
我的数据集:
SELECT 1 id, 'protoc1' protoc UNION ALL
SELECT 2 id, 'protoc2' protoc UNION ALL
SELECT 3 id, 'protoc3' protoc
不确定您为什么需要该输出,但我注意到您为所有行重复了数组,看起来您希望将数组表示为特定字符串——所以这是我对您所问内容的尝试:
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
下面使用
select id, format('%t', array_agg(protoc) over()) protoc
from your_table
如果应用于您问题中的示例数据 - 输出为