mybatis参数类型不匹配错误argument type mismatch的处理方案

网友投稿 2832 2022-11-08

mybatis参数类型不匹配错误argument type mismatch的处理方案

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 mismatchorg.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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:[leetcode] 111. Minimum Depth of Binary Tree
下一篇:docker: failed to register layer: devmapper: Unknown device
相关文章

 发表评论

暂时没有评论,来抢沙发吧~