mybatis中方法返回泛型与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;
返回结果
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。