对List进行分组(java8的Stream 分组的groupBy 的使用)

最近在做一个功能:对一个接口接收的List数据进行校验,同一个订单里的一个产品id只能添加一次。本来想是在入库的时候通过SQL语句进行处理的。但是由于这个数据接口之前同事写了很多的校验,是在是又*又长。在度娘上查一下,发现了JAVA8 可以通过Stream对List进行处理(这里主要是关于分组的);

Order order1 = new Order();
order1.setOrderId("123")Order1.setGoodsId("S1");

Order order2 = new Order();
order2.setOrderId("123")Order2.setGoodsId("S2");

Order order2 = new Order();
order2.setOrderId("1234")Order2.setGoodsId("S3");

List<Order> list =  new ArrayList();
List.add(order1);
List.add(order2);
List.add(order3);

Map<String,List<Order>> map = list.stream().collect(Collectors.groupingBy(ord -> ord.getOrderId));

其中Map<String,List> map 中的String 是 groupingBy里的属性;如果需要分组前进行判断,可以加个过滤;

Map<String,List<Order>> map = list.stream().filter(ord -> ord.getOrderId!= null)
.collect(Collectors.groupingBy(h -> h.getOrderID));

我要做的需要通过两个字段进行分组,所以我在groupingBy 里面加了两个字段;

Map<String,List<Order>> map = list.stream().collect(Collectors.groupingBy(ord -> ord.getOrderId+;+ ord.getOrderGoodsId()));

分组是按照groupingBy里面拼接的字段进行分组的,我这里加上";"主要是为了区分订单号和产品号;

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐