这篇文章主要介绍“如何解决mybatis中方法返回泛型与resultType不一致的问题”,在日常操作中,相信很多人在如何解决mybatis中方法返回泛型与resultType不一致的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的
这篇文章主要介绍“如何解决mybatis中方法返回泛型与resultType不一致的问题”,在日常操作中,相信很多人在如何解决mybatis中方法返回泛型与resultType不一致的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何解决mybatis中方法返回泛型与resultType不一致的问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
当xxxMaaper.java的方法返回值类型是List<A>,而xxxMappper.xml中对应的sql的resultType指定为B对象,这样是不会包错的(即使A与B不存在关系)
集合对象原本就是存储对象,可以是不同的对象List
直接处理List类型常常会出现类型转换异常,jdk5出现泛型,使得程序员向list中存放相同类型对象
泛型作用于编译阶段,仅为了防止类型混乱而出现,类型转换异常
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);}
<select id="increTrade" parameterType="java.util.Map" resultType="cn.easier.admin.model.A">//-------------</select>
resultType="java.util.HashMap"
</select> <select id="selectExceptionCountBymonths" resultType="java.util.HashMap" >SELECT DATE_FORMAT( report_date, '%Y%m' ) label , COUNT( 0 ) valueFROM 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;
返回结果
到此,关于“如何解决mybatis中方法返回泛型与resultType不一致的问题”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
--结束END--
本文标题: 如何解决mybatis中方法返回泛型与resultType不一致的问题
本文链接: https://lsjlt.com/news/299177.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0