Java通过Map实现与SQL中的group by相同的逻辑

在mysql8.0之后使用group by必须带上聚合函数,这在mysql-plus中无法直接实现,必须写sql语句才可以。下面通过Java的Map集合来实现类似的操作

1.在mybatis-plus中使用了gorup的原代码,思路是先查询了group by的对应字段,然后通过循环再进一步根据这个字段查询相关数据,整体步骤很繁琐,不比写一个mapper快多少。

复制代码
		LambdaQueryWrapper<JkgDataJson> jsonQueryWrapper1 = new LambdaQueryWrapper<>();
        jsonQueryWrapper1.eq(JkgDataJson::getJkgDataId, jkgData.getId());
        jsonQueryWrapper1.select(JkgDataJson::getLayerNumber);
        jsonQueryWrapper1.groupBy(JkgDataJson::getLayerNumber);
        List<JkgDataJson> jkgDataJsonList = jkgDataJsonMapper.selectList(jsonQueryWrapper1);

        for (int i = 0; i < jkgDataJsonList.size(); i++) {
            int layerNumber = jkgDataJsonList.get(i).getLayerNumber();
            LambdaQueryWrapper<JkgDataJson> jsonQueryWrapper2 = new LambdaQueryWrapper<>();
            jsonQueryWrapper2.eq(JkgDataJson::getJkgDataId, jkgData.getId());
            jsonQueryWrapper2.eq(JkgDataJson::getLayerNumber, layerNumber);
            List<JkgDataJson> jkgDataJsonList1 = jkgDataJsonMapper.selectList(jsonQueryWrapper2);
        }

2.通过Map实现分组

复制代码
 		//一次性查询当前所需的全部数据,通过分组字段放入map映射,后续的循环中就不需要每次去查询数据库了
        LambdaQueryWrapper<JkgDataJson> jsonWrapper = new LambdaQueryWrapper<>();
        jsonWrapper.eq(JkgDataJson::getJkgDataId, jkgData.getId());
        List<JkgDataJson> allDataJsonList = jkgDataJsonMapper.selectList(jsonWrapper);
        Map<Integer, List<JkgDataJson>> layerNumberMap = new HashMap<>();
        for (JkgDataJson dataJson : allDataJsonList) {
        	//这里放入map键的就是你需要分组的字段
            int layerNumber = dataJson.getLayerNumber();
            //在 Map 中查找指定key的值value,当layerNumber键不存在时,创建一个新的ArrayList插入到Map中
            layerNumberMap.computeIfAbsent(layerNumber, k -> new ArrayList<>()).add(dataJson);
        }

        for (Map.Entry<Integer, List<JkgDataJson>> entry : layerNumberMap.entrySet()) {
            int layerNumber = entry.getKey();
            List<JkgDataJson> jsonList = entry.getValue();
        }
相关推荐
golang学习记几秒前
Go 实时批处理:让数据库少挨点打 [特殊字符]
开发语言·数据库·golang
Memory_荒年1 分钟前
Netty:从“网络搬砖”到“流水线大师”的奇幻之旅
java·后端
ChaseDreamRunner15 分钟前
如何用 NSSM 把 Jar 做成 Windows 服务
java·windows·jar
神の愛16 分钟前
java的Aop
java·开发语言
左左右右左右摇晃28 分钟前
ConcurrentHashMap ——put + get
java·开发语言·笔记
今夕资源网37 分钟前
零基础 Python 环境搭建工具 一键安装 Python 环境自动配置 升级 pip、setuptools、wheel
开发语言·python·pip·环境变量·python环境变量·python自动安装
啥咕啦呛41 分钟前
java打卡学习4:HashMap底层结构、扩容机制
java·学习·哈希算法
qq_297574671 小时前
K8s系列第十四篇:K8s 故障排查实战:常见故障定位与解决方法
java·docker·kubernetes
Flittly1 小时前
【SpringAIAlibaba新手村系列】(3)ChatModel 与 ChatClient 的深度对比
java·人工智能·spring boot·spring
小CC吃豆子1 小时前
C++ 继承
开发语言·c++