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;
/**
* @Desc
* @Creator Hardy
* @Create_Date 2022/3/4 9:40
* @Updater
* @Update_Date
**/
public class MapResultHandler implements ResultHandler<Map> {
private final Map<String, String> mappedResults = new HashMap();
@Override
public void handleResult(ResultContext resultContext) {
Map<String, String> 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
<resultMap id="mapResult" type="java.util.HashMap">
<result property="key" column="name"/>
<result property="value" column="count"/>
</resultMap>
<select id="getMixingPlantProductionSummary" resultMap="mapResult">
SELECT
gsom.intensity_level AS name,
SUM(gsom.quantity) AS count
FROM
gt_szls_out_master gsom
<where>
<if test="orgId != null">
and gsom.org_id = #{orgId}
</if>
<if test="devSNs != null">
and gsom.dev_sn in (#{devSNs})
</if>
</where>
GROUP BY gsom.intensity_level
</select>
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就是我们一开始讲到的前端需要的数据类型
先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

本文介绍了如何在MySQL与MyBatis中将查询结果的两个字段作为Map的key和value,以满足前端展示需求。通过实现MapResultHandler.java、配置DAO接口与Mybatis.xml,以及详细讲解使用步骤,帮助开发者高效地转换数据结构。
2369

被折叠的 条评论
为什么被折叠?



