Flink DataStream之min()与minBy(),max()与maxBy()区别详解

在Flink中有一类滚动聚合的算子(Rolling Aggregation):

sum()、min()、minBy()、max()、maxBy()

其中,对于min()和minBy(),max()和maxBy()之间的区别,具体如下:

1、处理的数据只有两个字段:

即:只有分组字段和比较字段,

如城市温度数据(city,temp),其中city用来分组(keyBy),temp用来比较(min/minBy),

那么,此时min()和minBy()的作用是一样的,都是得到比较字段的最小值。案例代码如下:读者也可以自己写个demo测试一下。

public static void main(String[] args) throws Exception {
        Configuration conf = new Configuration();
        conf.setString("rest.port","8091");
        StreamExecutionEnvironment env = StreamExecutionEnvironment.createLocalEnvironmentWithWebUI(conf);
        //从端口号获取数据
        DataStreamSource<String> dataSource = env.socketTextStream("10.12.36.102", 8888);

        //=========================两个字段==============
        //将数据转化为Tu
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值