好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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时采用反射,是在运行时进行的,此时再看泛型容易进入误区

实例:

?

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;

返回结果

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

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

查看更多关于mybatis中方法返回泛型与resultType不一致的解决的详细内容...

  阅读:21次