MyBatis查询返回值为Map集合

通过@MapKey指定map的key值

1.在接口中写方法

java 复制代码
public interface IAccountDao {
    //返回一条记录的map;key就是列名,值就是对应的值
    Map<String,Object> selectAll(Integer id);

    /**
     * 此处若将map的key的类型改为其他类型,不影响@MapKey给map的key赋值
     * @return
     */
    @MapKey("name")//指定数据库中id字段作为map的key
    Map<String,Map<String,Object>> select();
}

2.在映射文件xml配置方法

原文链接

blog.csdn.net/xjszsd/arti...

遇到的小问题

用到的是第二种方法,目的是把平均分给统计上

java 复制代码
public List<SysActivityEvaluation> selectSysActivityEvaluationList(SysActivityEvaluation sysActivityEvaluation)
{
    //从平均分表中查出每个活动对应的平均分
    Map<String, Map<String,Object>> map = sysActivityEvaluationMapper.selectSysActivityEvaluationGrade();
    
    return sysActivityEvaluationMapper.selectSysActivityEvaluationList(sysActivityEvaluation)
            .stream()
            .map(s->{
        if (map.containsKey(s.getActivityId().toString())){
            System.out.println(1);
            BigDecimal two = new BigDecimal(map.get(s.getActivityId()).get("grade").toString());
            s.setGrade(two.setScale(2,BigDecimal.ROUND_HALF_DOWN).doubleValue());
        }
        return  s;
    }).collect(Collectors.toList());
}

代码很简单,如上图所示,但是有一个问题就是都可以获取到值activityId但是map.contains(s.getActivityId)却为null值;

经过一步步调试,我发现因为我的类型不一样,数据库里面是int类型,而我的实体类为Long类型,所以会找不到这个键,将其强转为Integer类型即可正常实现功能

相关推荐
程序员爱钓鱼32 分钟前
Go语言实战案例 — 项目实战篇:简易博客系统(支持评论)
前端·后端·go
追逐时光者7 小时前
精选 4 款基于 .NET 开源、功能强大的 Windows 系统优化工具
后端·.net
TF男孩7 小时前
ARQ:一款低成本的消息队列,实现每秒万级吞吐
后端·python·消息队列
AAA修煤气灶刘哥9 小时前
别让Redis「歪脖子」!一次搞定数据倾斜与请求倾斜的捉妖记
redis·分布式·后端
AAA修煤气灶刘哥9 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
你的人类朋友9 小时前
什么是API签名?
前端·后端·安全
昵称为空C11 小时前
SpringBoot3 http接口调用新方式RestClient + @HttpExchange像使用Feign一样调用
spring boot·后端
架构师沉默12 小时前
设计多租户 SaaS 系统,如何做到数据隔离 & 资源配额?
java·后端·架构
RoyLin12 小时前
TypeScript设计模式:适配器模式
前端·后端·node.js
该用户已不存在12 小时前
Mojo vs Python vs Rust: 2025年搞AI,该学哪个?
后端·python·rust