MySQL返回双列值使用map集合处理结果

在项目中实现了类似蚂蚁森林的用户碳能量汇总展示,通过SQL查询获取场景能量数据,如步行、骑行和公共出行的能量总和。使用MyBatis-Plus时,面对复杂查询结果,通常会用Model或Dto来接收,但在此场景下,选择了使用Map集合处理返回的结果集,通过XML文件修改方法返回类型并添加注解实现解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

最近做了一个功能,大概的场景是需要在前端展示一个用户在不同场景下的碳能量总和,类比于蚂蚁森林,页面需要显示

  • 步行场景:xxx能量
  • 骑行场景:xxx能量
  • 公共出行:xxx能量

问题描述

对于这个场景,sql语句其实是不难写的,问题在于怎么处理返回的结果集
sql如下:

select scene_rule_id sceneId,
       sum(emission) coSum
from co_scene_record
where member_id = '传入数据'
group by scene_rule_id

其中,scene_rule_id:场景id,emission:能量
此sql返回的数据如下
在这里插入图片描述
是一个双列的数据集


原因分析:

因为项目使用的是mybatis-plus,对于这种复杂查询,需要使用xml映射文件的方式去写sql语句来完成业务处理。在一般情况下,处理结果集一般使用model(或pojo或entity)类,或者使用Dto去直接接收sql语句的返回值,但是类似于这种情况,再写一个Dto,也是可以的,不过,,,,由于种种原因,最终采取了另外一种方案,使用map集合处理返回的结果集。


解决方案:

这里首先要在xml文件中将方法的返回值改为map集合
在这里插入图片描述

然后在接口上添加一个注解

在这里插入图片描述
打个断点测试一下输出的结果

在这里插入图片描述
完美解决

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值