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,特別當參數(shù)為實體類,一個屬性為list時,注意collection的名字。
2.遍歷時屬性的名字或者字段錯誤
3.多個參數(shù)時沒有使用@param進行命名,在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;
}
所以從上面可以看到中默認情況下寫的array和list,也就是collection默認的是array和list。
總結
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
- 解決mybatis-plus使用jdk8的LocalDateTime 查詢時報錯的方法
- SpringBoot集成MybatisPlus報錯的解決方案
- mybatis報錯元素內(nèi)容必須由格式正確的字符數(shù)據(jù)或標記組成異常的解決辦法
- Mybatis批量更新報錯問題
- Mybatis返回int或者Integer類型報錯的解決辦法
- Mybatis報錯: org.apache.ibatis.exceptions.PersistenceException解決辦法
- Oracle+Mybatis的foreach insert批量插入報錯的快速解決辦法
- MyBatis MapperProvider MessageFormat拼接批量SQL語句執(zhí)行報錯的原因分析及解決辦法
- MyBatis常見報錯問題及解決方案
相關文章
詳解Springboot如何優(yōu)雅的進行數(shù)據(jù)校驗
基于?Spring?Boot?,如何“優(yōu)雅”的進行數(shù)據(jù)校驗呢,本文將待大家詳細介紹Springboot如何優(yōu)雅的進行數(shù)據(jù)校驗,文中有詳細的代碼示例和流程步驟,需要的朋友可以參考下2023-06-06
詳解Java中l(wèi)ist,set,map的遍歷與增強for循環(huán)
這篇文章主要介紹了詳解Java中l(wèi)ist,set,map的遍歷與增強for循環(huán)的相關資料,需要的朋友可以參考下2017-02-02
教你使用idea搭建ssm詳細教程(Spring+Spring Mvc+Mybatis)
今天教大家使用idea搭建ssm詳細教程(Spring+Spring Mvc+Mybatis),文中有非常詳細的圖文介紹及代碼示例,對正在學習使用idea的小伙伴很有幫助,需要的朋友可以參考下2021-05-05
SpringBoot 使用@WebMvcTest測試MVC Web Controller
這篇文章主要介紹了SpringBoot 使用@WebMvcTest測試MVC Web Controller,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
Java的Hibernate框架中的雙向主鍵關聯(lián)與雙向外鍵關聯(lián)
Hibernate想要實現(xiàn)雙向的關聯(lián)就必須在映射文件的兩端同時配置<one-to-one>,另外還要在主映射的一端采用foreign外鍵關聯(lián)屬性,下面我們就一起來看一下Java的Hibernate框架中的雙向主鍵關聯(lián)與雙向外鍵關聯(lián)方法:2016-06-06

