作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用 Apache Flink 的 DataSet API,发现 sortPartition
转换仅支持位置和表达式键,但不支持键选择器函数。
我使用 java.util.Map
作为位置或表达式键不支持的数据类型。如何对 java.util.Map
等数据类型使用 sortPartition
转换?
最佳答案
Flink 的 key selector 函数是语法糖,可以很容易地通过两个 map 函数手动实现。
MapFunction
提取关键字段并返回 Tuple2<Key, Input>
其中键字段是提取的键,输入字段是原始输入(在您的情况下为 Map
)。 MapFunction
解开来自 Tuple2<Key, Input>
的输入字段元组。整体代码如下:
DataSet<Map> input = ...
DataSet<Tuple2<Long, Map>> keyed = input.map(new KeyExtractMap());
DataSet<Tuple2<Long, Map>> sortedKeyed = keyed.sortPartition(0, Order.ASCENDING);
DataSet<Map> sorted = sortedKeyed.map(new UnwrapMap());
关于java - Apache 弗林克 : Why does sortPartition transformation not support KeySelector functions,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34647109/
我是一名优秀的程序员,十分优秀!