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。

推薦閱讀: