jdk8按照多个字段对list分组

利用Java 8特性,通过创建一个重写equals和hashCode方法的Bean作为分组键,可以方便地对List对象按多个字段进行高效分组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对一个list列表,按照一个字段进行分组,jdk8方式很方便实现:

List<BillFeeVO> feeVOList = billFeeDao.listTotalFee(dto);
Map<Object, List<BillFeeVO>> feeGroup =  feeVOList.stream().filter(item->StringUtil.isNotBlank(item.getBizOperator()))
					.collect(Collectors.groupingBy(BillFeeVO::getBizOperator));

 

如果是按照多个字段进行分组,jdk8应该怎么实现呢?

首先生成一个Bean,重写equals和hashcode方法,把该Bean作为key即可。

 @Data
    @Builder
    private static class PickingGroupBean implements Comparable<PickingGroupBean> {

        // 库存占用明细 相关信息 -----
        // 库位id
        private Long storeLocationId;
        // 库位编码
        private String shelfOrder;
        // skuId
        private Long skuId;
        // 批次号
        private String batchNo;
        // 订单id
        private Long sendOrderMainId;
        // 单位id
        private Long unitId;
        // 库存占用明细 相关信息 -----

        @Override
        public int compareTo(PickingGroupBean o) {
            return shelfOrder.compareTo(o.shelfOrder);
        }

        @Override
        public boolean equals(Object o) {
            if (this == o) return true;
            if (o == null || getClass() != o.getClass()) return false;
            PickingGroupBean that = (PickingGroupBean) o;
            if (!Objects.equals(storeLocationId,
                    that.storeLocationId)) {
                return false;
            }
            if (!Objects.equals(skuId, that.skuId)) {
                return false;
            }
            return Objects.equals(batchNo, that.batchNo);
        }

        @Override
        public int hashCode() {
            return Objects.hash(storeLocationId, skuId, batchNo);
        }
    }



//分组
private Map<PickingGroupBean, List<StockAssignDetails>> groupStockAssignDetails(WaveGroup waveGroup,
                                                                                    List<StockAssignDetails> stockAssignDetailsList,
                                                                                    Map<Long, LocationVO> locationById) {
        // 1:分组
        Map<PickingGroupBean, List<StockAssignDetails>> groupedSAD = new HashMap<>();
        for (StockAssignDetails stockAssignDetail : stockAssignDetailsList) {
            String shelfOrder = Optional.ofNullable(locationById.get(stockAssignDetail.getStoreLocationId()))
                    .map(LocationVO::getShelfOrder)
                    .orElse("");
            PickingGroupBean pickingGroupBean = PickingGroupBean.builder()
                    .shelfOrder(shelfOrder)
                    .storeLocationId(stockAssignDetail.getStoreLocationId())
                    .skuId(stockAssignDetail.getSkuId())
                    .batchNo(stockAssignDetail.getBatchNo())
                    .sendOrderMainId(stockAssignDetail.getSendOrderMainId())
                    .unitId(stockAssignDetail.getUnitId())
                    .build();
            groupedSAD.computeIfAbsent(pickingGroupBean, k -> new ArrayList<>())
                    .add(stockAssignDetail);
        }
        log.info("分组({}): {}", waveGroup.getId(), JSON.toJSONString(groupedSAD, true));
        return groupedSAD;
    }

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值