mybatis参数类型不匹配错误argument type mismatch的处理方案
目录
- 参数类型不匹配错误argument type mismatch
- 错误日志
- 错误描述
- 错误原因
- 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
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。