栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value

MySQL.MyBatis怎么将查询的两个字段作为Map的key和value 问题的由来

前端使用Echarts图标显示汇总数据。需要形式如下的数据:

{
  "C20": 42.01,
  "C30": 1693.10,
  "C35": 231.00
}

但是经过以下的SQL查询

SELECt
	gsom.intensity_level AS  强度等级,
	SUM(gsom.quantity) AS  生产方量
FROM
	gt_szls_out_master gsom
WHERe org_id = '8100000000002334' AND dev_sn IN('00010001')
GROUP BY
	gsom.intensity_level

数据库查询出来的数据结果如下:

解决方案

其实观察一下前端需要的代码形式,我们只需要把SQL查询的结果中强度等级作为map的key,生产方量作为map的value即可。

实现上面的方案有一下几种方法:

  • 1、可以将查询的结果在java代码中进行遍历,组装成相应的结构返回给前端
  • 2、使用注解+拦截器的方式直接返回符合条件的Map(后面会讲)
  • 3、就是我们本次要讲的实现方式:通过改造SQL以及处理返回结果
1、MapResultHandler.java
import org.apache.ibatis.session.ResultContext;
import org.apache.ibatis.session.ResultHandler;

import java.util.HashMap;
import java.util.Map;


public class MapResultHandler implements ResultHandler {
    private final Map mappedResults = new HashMap();

    @Override
    public void handleResult(ResultContext resultContext) {
        Map m = (Map) resultContext.getResultObject();
        mappedResults.put(m.get("key"), m.get("value"));
    }

    public Map getMappedResults() {
        return mappedResults;
    }
}
2、xxxDao.java
void getMixingPlantProductionSummary(@Param("orgId") Long orgId, @Param("devSNs") String devSNs, MapResultHandler mapResultHandler);
3、Mybatis.xml

    
    



    SELECT
    gsom.intensity_level AS name,
    SUM(gsom.quantity) AS count
    FROM
    gt_szls_out_master gsom
    
        
            and gsom.org_id = #{orgId}
        

        
            and gsom.dev_sn in (#{devSNs})
        
    
    GROUP BY gsom.intensity_level

4、使用方式
MapResultHandler handler = new MapResultHandler();
xxxDao.getMixingPlantProductionSummary(orgId, devSNs, handler);
Map resultMap = handler.getMappedResults();

注意:

1、xxxDao.java中定义的接口返回值类型必须是void,如上面void getMixingPlantProductionSummary()

2、MyBatis.xml中定义的resultMap返回值类型是HashMap,其里面定义的两个result中的key要与MapResultHandler.java中代码mappedResults.put(m.get("key"), m.get("value"))保持一致;其value属性必须和Mybatis.xml中sql的返回值名称一致

3、Map resultMap = handler.getMappedResults();中的resultMap就是我们一开始讲到的前端需要的数据类型

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/851949.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号