亲宝软件园·资讯

展开

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

孙艳强 人气:5
想了解mybatis中方法返回泛型与resultType不一致的解决的相关内容吗,孙艳强在本文为您仔细讲解mybatis返回泛型与resultType不同的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:方法返回泛型,resultType,mybatis,resultType,下面大家一起来学习吧。

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

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

原因分析:

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

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

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

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

实例:

public class A
}
public class B{
}
@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文件

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

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

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

resultType="java.util.HashMap"
</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>
@ApiOperation(value = "按照月份统计报警条数",notes = "按照月份统计报警条数")
@GetMapping(value = "warnCountStatistics")
@ActionLog(value = "按照月份统计所有报警条数")
    public  List<Map<String,Object>>  warnCountStatistics(){
        List list = smokeDetectorRecordMapper.selectWarnCountBymonths();
        return list;

返回结果

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

加载全部内容

相关教程
猜你喜欢
用户评论