mybatis参数类型不匹配错误argument type mismatch的处理方案
参数类型不匹配错误argument type mismatch
错误日志
java.lang.RuntimeException: org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.ExecutorException: Error selecting key or setting result to parameter object. Cause: org.apache.ibatis.reflection.ReflectionException: Could not set property ‘id’ of ‘class xxxxxxxx’ with value ‘37997’ Cause: java.lang.IllegalArgumentException: argument type mismatch
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.ExecutorException: Error selecting key or setting result to parameter object. Cause: org.apache.ibatis.reflection.ReflectionException: Could not set property ‘id’ of ‘class com.fshows.lifecircle.marketcore.service.dal.lifecircle.dataobject.TpLifecircleQuotaDO’ with value ‘37997’ Cause: java.lang.IllegalArgumentException: argument type mismatch
错误描述
根据字面意思就是:参数类型不匹配
实际就是某个参数存储的,与传入的参数类型不一致
错误代码

错误原因
在mybatis:gen生成代码的时候,这个id参数生成类型resultType=“java.lang.Long”,但实际数据库类型是int,应该对应resultType=“java.lang.Integer”
只要将Long改为Integer,与数据库对应即可。
mybatis时argument type mismatch的坑
错误描述:参数类型不匹配
常见错误中 mybatis映射出现问题无非就
column名字错误、property字段名错误、resultMap id写错了 没对上、映射实体类属性类型和数据库字段类型对不上,
这个一般都是比较容易想到和发现的。
但是某一天 映射实体类 因为某些地方要数据处理,你写了一个有参构造,而没把无参构造补上,这时mybatis在映射的时候 (映射首先要创建对象) 就会出现异常,而此时的参数类型不匹配 正是指的构造参数类型不匹配 而非数据字段和属性不匹配!
例如
new PeopleVO(People p) 和 new People() debug下可以看到会报错参数People类型错误
所以在开发中 该遵循的规则 还是要遵循,相信不少人在初学java的时候 一定听过 写了有参构造一定要手动把无参构造写上,当时我想的是 要是用上无参构造new对象 编译器也会提示,用的时候在new也不迟 况且还不一定用得上,
可是在mybatis映射的时候 想不到吧 人家反射创建对象了… 不由感慨 前人的总结都是踩了无数坑的基础上建立起来的,那些表面看起来不会有问题的代码 可能会以某种意想不到的形式出现bug
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
SpringBoot集成SpringSecurity和JWT做登陆鉴权的实现
这篇文章主要介绍了SpringBoot集成SpringSecurity和JWT做登陆鉴权的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-04-04
Java Timezone类常见问题_动力节点Java学院整理
这篇文章主要介绍了Java Timezone类常见问题的相关资料,需要的朋友可以参考下2017-05-05
解决tomcat发布工程后,WEB-INF/classes下文件不编译的问题
这篇文章主要介绍了解决tomcat发布工程后,WEB-INF/classes下文件不编译的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-12-12


最新评论