mybatis中foreach報錯:_frch_item_0 not found的解決方法
發(fā)現(xiàn)問題
在mybatis的動態(tài)sql中最常見的錯誤就是使用,比如:_frch_item_0 not found
There is no getter for property named 'states' in 'class com.xingguo.model.User'
等等。
一般在使用時出現(xiàn)問題是由以下幾種錯誤使用方式造成的:
1.參數(shù)類型不是List,特別當(dāng)參數(shù)為實體類,一個屬性為list時,注意collection的名字。
2.遍歷時屬性的名字或者字段錯誤
3.多個參數(shù)時沒有使用@param進(jìn)行命名,在sql中順序混亂
下面從MySQL的源碼中看下對于list參數(shù)是如何解析的。
首先看到DefaultSqlSession.Java中的wrapCollection()
方法:
private Object wrapCollection(final Object object) { if (object instanceof Collection) { StrictMap<Object> map = new StrictMap<Object>(); map.put("collection", object); if (object instanceof List) { map.put("list", object); } return map; } else if (object != null && object.getClass().isArray()) { StrictMap<Object> map = new StrictMap<Object>(); map.put("array", object); return map; } return object; }
所以從上面可以看到中默認(rèn)情況下寫的array和list,也就是collection默認(rèn)的是array和list。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- 解決mybatis-plus使用jdk8的LocalDateTime 查詢時報錯的方法
- SpringBoot集成MybatisPlus報錯的解決方案
- mybatis報錯元素內(nèi)容必須由格式正確的字符數(shù)據(jù)或標(biāo)記組成異常的解決辦法
- Mybatis批量更新報錯問題
- Mybatis返回int或者Integer類型報錯的解決辦法
- Mybatis報錯: org.apache.ibatis.exceptions.PersistenceException解決辦法
- Oracle+Mybatis的foreach insert批量插入報錯的快速解決辦法
- MyBatis MapperProvider MessageFormat拼接批量SQL語句執(zhí)行報錯的原因分析及解決辦法
- MyBatis常見報錯問題及解決方案
相關(guān)文章
詳解Springboot如何優(yōu)雅的進(jìn)行數(shù)據(jù)校驗
基于?Spring?Boot?,如何“優(yōu)雅”的進(jìn)行數(shù)據(jù)校驗?zāi)?,本文將待大家詳?xì)介紹Springboot如何優(yōu)雅的進(jìn)行數(shù)據(jù)校驗,文中有詳細(xì)的代碼示例和流程步驟,需要的朋友可以參考下2023-06-06詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)
這篇文章主要介紹了詳解Java中l(wèi)ist,set,map的遍歷與增強(qiáng)for循環(huán)的相關(guān)資料,需要的朋友可以參考下2017-02-02教你使用idea搭建ssm詳細(xì)教程(Spring+Spring Mvc+Mybatis)
今天教大家使用idea搭建ssm詳細(xì)教程(Spring+Spring Mvc+Mybatis),文中有非常詳細(xì)的圖文介紹及代碼示例,對正在學(xué)習(xí)使用idea的小伙伴很有幫助,需要的朋友可以參考下2021-05-05SpringBoot 使用@WebMvcTest測試MVC Web Controller
這篇文章主要介紹了SpringBoot 使用@WebMvcTest測試MVC Web Controller,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11Java的Hibernate框架中的雙向主鍵關(guān)聯(lián)與雙向外鍵關(guān)聯(lián)
Hibernate想要實現(xiàn)雙向的關(guān)聯(lián)就必須在映射文件的兩端同時配置<one-to-one>,另外還要在主映射的一端采用foreign外鍵關(guān)聯(lián)屬性,下面我們就一起來看一下Java的Hibernate框架中的雙向主鍵關(guān)聯(lián)與雙向外鍵關(guān)聯(lián)方法:2016-06-06Java8中Optional的一些常見錯誤用法總結(jié)
我們知道 Java 8 增加了一些很有用的 API, 其中一個就是 Optional,下面這篇文章主要給大家介紹了關(guān)于Java8中Optional的一些常見錯誤用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-07-07