mybatis中方法返回泛型与resultType不一致的解决

时间:2021-07-23 14:48:58

mybatis方法返回泛型与resultType不一致

当xxxMaaper.java的方法返回值类型是List<A>,而xxxMappper.xml中对应的sql的resultType指定为B对象,这样是不会包错的(即使A与B不存在关系)

原因分析:

1.集合对象原本就是存储对象,可以是不同的对象List

2.直接处理List类型常常会出现类型转换异常,jdk5出现泛型,使得程序员向list中存放相同类型对象

3.泛型作用于编译阶段,仅为了防止类型混乱而出现,类型转换异常

4.mybatis结果集封装bean时采用反射,是在运行时进行的,此时再看泛型容易进入误区

实例:

?
1
2
3
4
public class A
}
public class B{
}
?
1
2
3
4
5
6
7
8
9
10
11
@Service()
public class AImpl implements AService {
private AMapper  aMapper ;
public List<B> increTrade(Map<String, Object> map) {
List<B> lst =aMapper.increTrade(map); //这里debug看到list是A类型,此时泛型误导人
return lst;
}
}
public interface AMapper {
List<B>increTrade(Map<String, Object> map);
}

AMapper 对应的xml文件

?
1
2
3
<select id="increTrade" parameterType="java.util.Map" resultType="cn.easier.admin.model.A">
//-------------
</select>

List中map泛型对应mybatis的返回类型

List<Map<String,Object>>在mybatis对应

?
1
resultType="java.util.HashMap"
?
1
2
3
4
5
6
7
8
9
10
11
12
</select>
  <select id="selectExceptionCountBymonths" resultType="java.util.HashMap"  >
SELECT
 DATE_FORMAT( report_date, '%Y%m' ) label ,
 COUNT( 0 ) value
FROM
 t_smoke_detector_record
 WHERE tsdr_type != "火灾告警"
GROUP BY
 label
 
  </select>
?
1
2
3
4
5
6
@ApiOperation(value = "按照月份统计报警条数",notes = "按照月份统计报警条数")
@GetMapping(value = "warnCountStatistics")
@ActionLog(value = "按照月份统计所有报警条数")
    public  List<Map<String,Object>>  warnCountStatistics(){
        List list = smokeDetectorRecordMapper.selectWarnCountBymonths();
        return list;

返回结果

mybatis中方法返回泛型与resultType不一致的解决

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/yuhuafeixian/article/details/77897247