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寫錯了 沒對上、映射實體類屬性類型和數據庫字段類型對不上,
這個一般都是比較容易想到和發(fā)現的。
但是某一天 映射實體類 因為某些地方要數據處理,你寫了一個有參構造,而沒把無參構造補上,這時mybatis在映射的時候 (映射首先要創(chuàng)建對象) 就會出現異常,而此時的參數類型不匹配 正是指的構造參數類型不匹配 而非數據字段和屬性不匹配!
例如
new PeopleVO(People p) 和 new People() debug下可以看到會報錯參數People類型錯誤
所以在開發(fā)中 該遵循的規(guī)則 還是要遵循,相信不少人在初學java的時候 一定聽過 寫了有參構造一定要手動把無參構造寫上,當時我想的是 要是用上無參構造new對象 編譯器也會提示,用的時候在new也不遲 況且還不一定用得上,
可是在mybatis映射的時候 想不到吧 人家反射創(chuàng)建對象了… 不由感慨 前人的總結都是踩了無數坑的基礎上建立起來的,那些表面看起來不會有問題的代碼 可能會以某種意想不到的形式出現bug
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
idea如何修改文件的file is read-only問題
這篇文章主要介紹了idea如何修改文件的file is read-only問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
Java ArrayList的基本概念和作用及動態(tài)數組的機制與性能
在Java中,ArrayList是一個實現了List接口的動態(tài)數組,它可以根據需要自動增加大小,因此可以存儲任意數量的元素,這篇文章主要介紹了探秘Java ArrayList的基本概念和作用及動態(tài)數組的機制與性能,需要的朋友可以參考下2023-12-12
SpringMVC @RequestBody屬性名大寫字母注入失敗的解決
這篇文章主要介紹了SpringMVC @RequestBody屬性名大寫字母注入失敗的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04

