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();
        }
相关推荐
闻哥几秒前
从测试坏味道到优雅实践:打造高质量单元测试
java·面试·单元测试·log4j·springboot
smileNicky1 分钟前
统一网关的登录流程总结
java
June bug5 分钟前
【高频SQL基础版】排序和分组
数据库·sql
计算机程序设计小李同学13 分钟前
基于 Spring Boot + Vue 的龙虾专营店管理系统的设计与实现
java·spring boot·后端·spring·vue
LiZhen79818 分钟前
SpringBoot 实现动态切换数据源
java·spring boot·mybatis
玄同76521 分钟前
LangChain 1.0 模型接口:多厂商集成与统一调用
开发语言·人工智能·python·langchain·知识图谱·rag·智能体
特立独行的猫a25 分钟前
C++轻量级Web框架介绍与对比:Crow与httplib
开发语言·前端·c++·crow·httplib
fie888926 分钟前
基于C#的推箱子小游戏实现
开发语言·c#
周航宇JoeZhou27 分钟前
JB2-7-HTML
java·前端·容器·html·h5·标签·表单
菜鸟小芯35 分钟前
Qt Creator 集成开发环境下载安装
开发语言·qt