自定义mapper文件时出现报错:@MapKey is required
但是并没有影响程序的编译和输出,输出结果:{name=Tom, id=3, age=28, email=111@111.com}
于是上网查询一番,总结如下:
一、其实不用管这个警告也行,只是由于强迫症,还是想解决一下这个问题,那么就请看下面的两种方式2和3.
二、使用注解@MapKey,就不报警告了。
使用方法:
@MapKey("name")
Map<String,Object> selectMapById(Long id);
其中()中定义的是Map集合的key,也可以理解成输出时候Map集合的key键是数据库中name字段的值。
下面举例说一下:
先看一下我数据库:
测试方法如下:MySql的id字段为bigint 类型
@Test
public void selsctMapById() {
Map<String, Object> map = userMapper.selectMapById(3L);
System.out.println(map);
}
那么上面注解@MapKey("name")的输出结果就是:
{Tom={name=Tom, id=3, age=28, email=111@111.com}}
Tom 就是查询出来的name字段的名字,把它做为Map的key,其余的内容都做为Value
继续修改注解@MapKey("id"),输出结果是:
{3={name=Tom, id=3, age=28, email=111@111.com}}
这时key 就是字段id对应的值:3
三、去除Mybatis映射方法检查(Mapper method inspection)
方法:
=============================分割线===============================
主要用作记录之用,方法二适合全新开发项目时使用,方法三适合原有项目尽量少修改代码时使用,毕竟只是警告不会影响正常编译。
希望能帮到大家。