1.现在有一个商品ID与批次ID,来确保唯一,需要获取商品列表中的数量总和,由于点单的商品列表购物车是乱序的,而且商品列表中,数量有多个,比如洗发水可能是买了三瓶,或者四瓶。
2.思路:当已经确定需求是有唯一键的时候,可以优先考虑map的结构,因为map是主键唯一,二次主键使用的时候,进行put的时候,则会被覆盖掉原有的值,当然这个结构也是可以去重的,因为要保证唯一性的数据结构
{"key":"value"}
3.根据1的需求,可以看出,有一个确定的唯一可以作为主键,那么我们可以使用,storeID + batchID 来确保key的唯一性进行使用上代码:
Map<String,Integer> shopingCartMap = new HashMap<>();
//将所有购物车的商品,统计购物车相同批次产品总数量
for (JSalesDetailDimensionItem item : dimensionItems){
String key = item.getProductId() + "_" + item.getProductionBatchNum();
//如果key存在该map中则进行叠加
if(shopingCartMap.containsKey(key)){
//将值取出来,相同的购物车的商品,数量就会动态进行累积
Integer quantity = shopingCartMap.get(key);
shopingCartMap.put(key,quantity + item.getQuantity());
}else {
shopingCartMap.put(key,item.getQuantity());
}
}
方式二 Java8 Stream流式编程
Collectors.groupingBy((GoodsVo::getBrand) 使用该方式进行Key,Value的分类即可
public Map<String, List<GoodsVo>> getGoodsInfoByBands(List<String> bands) {
//根据品牌查询商品
LambdaQueryWrapper<Goods> lqw = Wrappers.lambdaQuery();
lqw.in(Goods::getBrand, bands);
List<GoodsVo> goodsVos=baseMapper.selectVoList(lqw);
if(CollectionUtils.isNotEmpty(goodsVos)){
Map<String, List<GoodsVo>> collect = goodsVos.stream().collect(Collectors.groupingBy((GoodsVo::getBrand)));
return collect;
}
return null;
}