【发布时间】:2021-12-18 15:34:36
【问题描述】:
我有一个 presto 数组,无论数组中的值是什么,我都需要过滤掉奇数索引。
Array = ['no', 'matter', 'what', 'is, 'here']
期望的结果 = ['matter', 'is']
我尝试了很多不同的 sequence(2, cardinality(Array), 2) 变体,但似乎没有任何效果。
【问题讨论】:
我有一个 presto 数组,无论数组中的值是什么,我都需要过滤掉奇数索引。
Array = ['no', 'matter', 'what', 'is, 'here']
期望的结果 = ['matter', 'is']
我尝试了很多不同的 sequence(2, cardinality(Array), 2) 变体,但似乎没有任何效果。
【问题讨论】:
我最终用我创建的索引数组压缩了数组
zip(ar, sequence(1, cardinality(ar), 1))
然后我在x -> x[2]%2=0 上过滤x[2] 并仅选择x -> x[1] 并进行转换。
其他地方的一些其他建议是用序数取消嵌套,在序数列上过滤然后聚合回来。
【讨论】:
另一种方法 - 生成仅需要的索引序列(对于偶数索引 - 从 2 开始并将 step 设置为 2)并在其上使用 transform:
WITH dataset(arr) AS ( values (array[1,2,3,4,5]) )
SELECT transform(sequence(2, cardinality(arr), 2), i -> arr[i])
FROM dataset
输出:
| _col0 |
|---|
| [2, 4] |
【讨论】: