MyBatis中foreach標簽的collection屬性的取值方式
foreach標簽的collection屬性的取值
傳的是List列表
接口代碼
List<Emp> findEmpByDeptnos(List<Integer> deptnos);
xml配置代碼
<select id="findEmpByDeptnos" resultType="Emp" parameterType="list"> SELECT * FROM emp e WHERE e.deptno IN <foreach collection="list" item="deptno" open="(" separator="," close=")"> #{deptno} </foreach> </select>
傳的是Array數組
接口代碼
List<Emp> findEmpByDeptnos(Integer[] deptnos);
xml配置代碼
<select id="findEmpByDeptnos" resultType="Emp" parameterType="int"> SELECT * FROM emp e WHERE e.deptno IN <foreach collection="array" item="deptno" open="(" separator="," close=")"> #{deptno} </foreach> </select>
傳的是Map
接口代碼
List<Emp> findEmpByDeptnos(Map<String,List<Integer>> deptnos);
xml配置代碼
<select id="findEmpByDeptnos" resultType="Emp" parameterType="map"> SELECT * FROM emp e WHERE e.deptno IN <foreach collection="myKey" item="deptno" open="(" separator="," close=")"> #{deptno} </foreach> </select>
collection屬性總結
- 如果傳入的參數是List,則填寫list
- 如果傳入的參數是數組形式,則填寫array
- 如果是多參數傳參,傳的是map,則填寫列表的鍵key
MyBatis使用foreach標簽報錯
在使用mybatis過程中,<foreach>標簽算是比較常用的,最近在項目中遇到這樣一個問題,使用<foreach>標簽循環拼接SQL語句時
報瞭一個錯誤:
nested exception is org.apache.ibatis.reflection.ReflectionException: There is no getter for property named ‘__frch_name_0’ in ‘class com.stand.modules.address.param.GeneralAddressQueryParam’
比較疑惑,這個標簽使用瞭很多次瞭,還是第一次遇到這樣的問題,通過查閱資料,得到瞭解決方案。
原因
首先貼出涉及到的實體類、Mapper接口和對應的XML部分代碼
用於Mapper接口傳參的實體類:
public class GeneralAddressQueryParam implements Serializable { /** * 地名,多級地名用逗號分隔 */ private String names; /** * 多地名查詢條件 */ private List<String> nameList; public String getNames() { return names; } public void setNames(String names) { this.names = names; } public List<String> getNameList() { return nameList; } public void setNameList(List<String> nameList) { this.nameList = nameList; } }
Mapper接口
List<GeneralAddressFullNameDTO> multiNameQuery(GeneralAddressQueryParam queryParam);
XML部分代碼
<if test="nameList != null and nameList.size() > 0"> <foreach collection="nameList" item="name"> and address like concat('%', #{name}, '%') </foreach> </if>
以上就是問題涉及到的部分代碼,出錯的原因呢,就是在<foreach>標簽中取值出的錯,網上查閱資料說是因為parameterType接收的參數不是List導致的,具體情況未核實。
解決方案
解決方法比較簡單,或一種取值方式即可,將<foreach>標簽中遍歷出來的值換做如下方式獲取
<if test="nameList != null and nameList.size() > 0"> <foreach collection="nameList" item="name" index="index"> and address like concat('%', #{nameList[${index}]}, '%') </foreach> </if>
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- MyBatis傳入參數為List對象的實現
- mybatis條件語句中帶數組參數的處理
- Mybatis中的@Select、foreach用法
- mybatis update更新字段的使用操作
- mybatis in查詢傳入String方式