oksice 2023-09-11 12:10 采纳率: 75%
浏览 5

查询返回list太大如何避免?

Mapper层查询List返回五百万行的大量数据,一般也使用guava的工具包分批次处理吗?这个list太大了,虽然处理可以分批次,但看起来它本身就挺大会占用太多资源,有其他较好处理方式嘛?

//import com.google.common.collect.Lists;
@Autowired
private Mapper mapper;
//查询清单
List<Map> list = mapper.qryXxxList();
List<List<Map>> newList = Lists.partition(rules , 100000);
list.stream().map(item -> {
//TODO 逻辑处理
return item;}).collect(Collectors.toList());

笔者追加:我想还是要对sql管控,mod之类的让它一次别查出太多,通过代码应该没啥作用,因为查出来给到list时已经占用太多了。

  • 写回答

3条回答 默认 最新

  • 梦幻精灵_cq 2023-09-11 12:19
    关注
    • 可不可以用iter()函数,把返回的list变成迭代器,它应该就不大了吧😄

      img


    评论 编辑记录

报告相同问题?

问题事件

  • 修改了问题 9月11日
  • 创建了问题 9月11日

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看