项目场景:
最近做了一个功能,大概的场景是需要在前端展示一个用户在不同场景下的碳能量总和,类比于蚂蚁森林,页面需要显示
- 步行场景: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集合
然后在接口上添加一个注解
打个断点测试一下输出的结果
完美解决