2

我面临一个与我的项目相关的问题。这是我想做的总结:

我有一个很大的每日文件(100 Go),其中包含以下摘录(无标题):

ID_A|segment_1
ID_A|segment_2
ID_B|segment_2
ID_B|segment_3
ID_B|segment_4
ID_B|segment_5
ID_C|segment_1
ID_D|segment_2
ID_D|segment_4

每个 ID(从 A 到 D)都可以链接到一个或多个段(从 1 到 5)。

我想处理这个文件以获得以下结果(结果文件包含一个标题):

ID|segment_1|segment_2|segment_3|segment_4|segment_5
ID_A|1|1|0|0|0
ID_B|0|1|1|1|1
ID_C|1|0|0|0|0
ID_D|0|1|0|1|0

1表示 ID 包含在段中,0表示不包含。

我正在使用以下查询来获取结果:

select id,
       countif(segment = 'segment_1') as segment_1,
       countif(segment = 'segment_2') as segment_2,
       countif(segment = 'segment_3') as segment_3,
       countif(segment = 'segment_4') as segment_4,
       countif(segment = 'segment_5') as segment_5
from staging s cross join
     unnest(split(segments, ',')) as segment
group by id;

这个解决方案对我有用,直到段数变得更多(在我的第一个示例中,900 多个段而不是 5 个)。这会创建一个无法通过bqcli 作为参数传递的巨大查询。

有什么我可以使用的解决方法吗?

感谢大家的帮助。

问候

4

1 回答 1

1

以下是 BigQuery 标准 SQL

EXECUTE IMMEDIATE '''
SELECT id, ''' || (
  SELECT STRING_AGG("COUNTIF(segment = '" || segment || "') AS " || segment ORDER BY segment)
  FROM (SELECT DISTINCT segment FROM staging)  
) || '''  
FROM staging
GROUP BY 1
ORDER BY 1
'''     

如果适用于您问题中的样本数据 - 输出是

Row id      segment_1   segment_2   segment_3   segment_4   segment_5    
1   ID_A    1           1           0           0           0    
2   ID_B    0           1           1           1           1    
3   ID_C    1           0           0           0           0    
4   ID_D    0           1           0           1           0  

正如你所看到的,你不需要担心段的数量和命名 - 它由上面的查询处理

于 2020-07-26T20:59:35.103 回答