Stream练习——groupingBy分组

 *需求说明:
 * 涉及一个对外提供服务的接口,支持调用方传入多个账户编号查询订单
public class Case_4 {

    @Data
    @AllArgsConstructor
    class Order {
        private Integer orderId;
        private String accountId;
    }

    /**
     * 模拟数据库查询
     * @param accountIds
     * @return
     */
    public List<Order> selectFromDB(List<String> accountIds){
        List<Order> orderList = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            orderList.add(
                    new Order(i,accountIds.get(i%accountIds.size( )))
            );
        }
        return orderList;
    }

    /**
     * 这个接口符合原需求,但是对调用方不够友好,因为查询出的数据还需要调用方去分组
     * @param accountIds
     * @return
     */
    public List<Order> queryOrderByAccountIds(List<String> accountIds){
        List<Order> orderList = selectFromDB(accountIds);
        return orderList;
    }

    /**
     * 这个接口不仅符合需求,且对结果进行了分类包装,让调用者一目了然
     * @param accountIds
     * @return
     */
    public Map<String,List<Order>> queryOrderByAccountIdsMap(List<String> accountIds){
        Map<String, List<Order>> result = Optional.ofNullable(selectFromDB(accountIds))
                .map(List::stream)
                .orElseGet(Stream::empty)
                .collect(Collectors.groupingBy(
                        order -> order.getAccountId()
                ));

        return result;
    }

    @Test
    public void test(){
        List<Order> orders_1 = queryOrderByAccountIds(Lists.newArrayList("张三", "李四", "王五"));
        Map<String, List<Order>> orders_2 = queryOrderByAccountIdsMap(
                Lists.newArrayList("张三", "李四", "王五")
        );

        System.out.println(JSON.toJSONString(orders_1,true));
        System.out.println("==========两种结果对比参考=============");
        System.out.println(JSON.toJSONString(orders_2,true));
    }
}

j结果展示

[
{"accountId":"张三","orderId":0},
{"accountId":"李四","orderId":1},
{"accountId":"王五","orderId":2},
{"accountId":"张三","orderId":3},
{"accountId":"李四","orderId":4},
{"accountId":"王五","orderId":5},
{"accountId":"张三","orderId":6},
{"accountId":"李四","orderId":7},
{"accountId":"王五","orderId":8},
{"accountId":"张三","orderId":9}
]
==========两种结果对比参考=============
{
"李四":
[{"accountId":"李四","orderId":1},
{"accountId":"李四","orderId":4},
{"accountId":"李四","orderId":7}],
"张三":
[{"accountId":"张三","orderId":0},
{"accountId":"张三","orderId":3},
{"accountId":"张三","orderId":6},
{"accountId":"张三","orderId":9}],
"王五":
[{"accountId":"王五","orderId":2},
{"accountId":"王五","orderId":5},
{"accountId":"王五","orderId":8}]
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值