使用List的stream将List集合转成Map

具体的情况是查询出来店铺的订单列表信息,然后每条信息需要加上用户的信息----->订单表中有用户id,最开始偷懒想快点写完(怕数据量大导致查的慢就也没写关联sql),查出来当前店铺的订单列表后,直接使用了for循环查询数据库,后来自己测一遍发现这种方式太离谱,就改造了一下。

具体实现方式如下:

// 定义返回的对象
List<OrderDTO> resultOrders = new ArrayList<>();

String storeId = "店铺id";

// 查询出店铺订单列表
List<StoreOrderListDTO> storeOrderList = orderMapper.findStoreOrderList(storeId);

// 将userId抽离出来组成一个userId集合
List<String> userIds = orderList
					.stream()
					.map(StoreOrderListDTO::getUserId)
					.collect(Collectors.toList());
					
// 此时查询来这些用户信息
List<UserInfo> userList = userMapper.listByIds(userIds);

// 将用户信息集合转成Map<Long, UserInfo>
Map<String, UserInfo> userMap = userList
					.stream()
					.collect(Collectors
								.toMap(CyConsumerUser::getUserId, cyConsumerUser -> cyConsumerUser));
Map<String, List<UserInfo>> finalUserInfoMap = userMap;
								
// 然后将用户信息设置到返回的DTO中
storeOrderList.forEach(storeOrderItem->{
	OrderDTO orderDTO = new OrderDTO;
	
	// 拷贝对象属性,第一个参数数源,第二个参数是目标
	BeanUtils.copyProperties(storeOrderItem, orderDTO );
	
	// 设置用户信息
	UserInfo userInfo = finalUserInfoMap.get(storeOrderItem.getUserId());
	BeanUtils.copyProperties(storeOrderItem, userInfo);
	
	resultOrders.add(orderDTO);
})

// 最后返回结果
return resultOrders;

记录一下碰到的一个问题,方便以后用到stream的这些用法然后直接复制拿来用,大神看到了别喷,刚工作比较菜,只能想到这种方式来进行改造。

(判空逻辑和其他的逻辑就没写了,只是自己针对此问题的一个实现方式)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值