java duplicate key_Stream 操作 Duplicate key问题

发布时间:2024年01月05日

背景:有一个用户订单查询首页(默认查询最近20条订单同时支持多条件查询),订单有多种,比如分销单,买家单,活动单等等,现在有一个需求,对于分销买家单需要添加供销商的一个信息。通过SupplierShopId作为参数 调用远端接口可以获取SupplierShopName。

开发思考:由原先的单次掉用修改为批量调用,店铺方面给的批量查询接口最大支持查询量为20条,对于多条件查询如果修改pageSize 需要多次调用,这边需要获取分销买家单进行数量计算,所以首先需要获取分销买家单数量。这边使用流操作先进行一次业务标判断过滤出符合条件的单子。获取到单子进行批量接口调用计算,将调用返回结果添加进入list集合里面。list的对象类型为定义的一个bo(拥有店铺id和店铺别名两个属性)最简单的方法是使用两个for循环,将bo中的店铺id和list中每个对象的店铺id 进行匹配,放入特定ordertail中。考虑时间效率使用map进行优化key 为店铺id ,value为店铺名字

遇到坑点:Stream 流操作后报错 Duplicate key

stream()

.collect(

Collectors.toMap(ShopMetaInfo::getKdtId, ShopMetaInfo::getShopName));

复制代码

原因:

多个分销单可能存在同一个供货商情况。

解决方案:

在java8中Collectors类中的tomap方法提供了我们将数据转换成Map的封装,往往在我们应用2个参数的(我们声明Key和Value很直接如下图)前提是key不能重复

b7fb73fb497e2e8e0c3eb9fb78034be9.png

其实java8已经给我们提供了解决的方式: 方法的第三个参数体现的

其实java8已经给我们提供了解决的方式: 方法的第三个参数体现的

2d031ebb7080c5463960689d63a98bc2.png

java8处理思路:即 两个key相同时 只能有一个key存在,那对应的value如何处理? value就是这样处理(我们自己来写方法体,我只是简单的拿逗号拼接下)

文章来源:https://blog.csdn.net/qq_43985303/article/details/135377464
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。