• 巧用Stream:像sql一样操作数据集合


    背景:

      从数据库中查询出的数据,最各种运算。Stream最方便。 

    //转Map操作 实体中的2个字段,转为key=字段 value=字段
    Map<String, Integer> collect = studentList.stream().collect(Collectors.toMap(Student::getGroupPointId, Student::getGroupStatus));

    //转Map操作 key=某个字段,value=实体对象
    Map<String, Student> studentDBMap = studentList.stream().collect(Collectors.toMap(Student::getGroupNo,v->v,(o,n)->n));

    //分组统计,key-List
    Map<Long, List<MapDic>> dicMap = mapDics.stream().collect(groupingBy(m -> m.getMapAreaId()));

    //分组统计
    Map<String, Long> storageCountMap = request.getStorageList().stream().collect(Collectors.groupingBy(Student::getAge, Collectors.counting()));

    //多级分组 统计
    Map<Long,Map<String,List<Student>>> map = points.stream().collect(groupingBy(e->e.getMapAreaId(),
    groupingBy(e -> e.getLogicalCode()+"_"+e.getLogicalName())));

    //转list
    List<Stream> itemList = studentStreams.stream().map(this::getStreamObj).collect(Collectors.toList());
    List<String> alleyNoStrList = alleyList.stream().map(Student::getAge).collect(Collectors.toList());

    ==========================================================================           如果您觉得这篇文章对你有帮助,可以【关注我】或者【点赞】,希望我们一起在架构的路上,并肩齐行
    ==========================================================================
  • 相关阅读:
    js实现H5、触摸屏数字键盘
    MAC 下node.js初体验 开发环境搭建
    手动搭建一个完整的angular实践项目
    js实现H5页面手指滑动刻度尺
    JavaScript中的事件循环机制
    CentOS6.5安装教程
    通过ecplise导入mysql的jar包时,右键找不到build path问题
    Java数据库之数据库的连接操作
    Java基础之文件的输入输出流操作
    数据库约束
  • 原文地址:https://www.cnblogs.com/amberJava/p/12983562.html
Copyright © 2020-2023  润新知