mybatis中傳帶逗號的集合時 報異常 invalid comparison: java.util.Arrays$ArrayList and java.lang.String

foreach的主要用在構建in條件中,它可以在SQL語句中進行迭代一個集合。
foreach元素的屬性主要有item,index,collection,open,separator,close。
item表示集合中每一個元素進行迭代時的別名。
index指定一個名字,用於表示在迭代過程中,每次迭代到的位置。

open表示該語句以什麼開始。
separator表示在每次進行迭代之間以什麼符號作爲分隔符,
close表示以什麼結束,在使用foreach的時候最關鍵的也是最容易出錯的就是collection屬性,該屬性是必須指定的,但是在不同情況下,該屬性的值是不一樣的,

主要有一下3種情況:

如果傳入的是單參數且參數類型是一個List的時候,collection屬性值爲list .
如果傳入的是單參數且參數類型是一個array數組的時候,collection的屬性值爲array .

如果傳入的參數是多個的時候,我們就需要把它們封裝成一個Map了,當然單參數也可以封裝成map,實際上如果你在傳入參數的時候,在MyBatis裏面也是會把它封裝成一個Map的,map的key就是參數名,所以這個時候collection屬性值就是傳入的List或array對象在自己封裝的map裏面的key.
下面我們通過代碼實踐:

<!--List:forech中的collection屬性類型是List,collection的值必須是:list,item的值可以隨意,Dao接口中參數名字隨意 -->
<select id="getEmployeesListParams" resultType="Employees">
    select *
    from EMPLOYEES e
    where e.EMPLOYEE_ID in
    <foreach collection="list" item="employeeId" index="index"
        open="(" close=")" separator=",">
        #{employeeId}
    </foreach>
</select>


<!--Array:forech中的collection屬性類型是array,collection的值必須是:list,item的值可以隨意,Dao接口中參數名字隨意 -->
<select id="getEmployeesArrayParams" resultType="Employees">
    select *
    from EMPLOYEES e
    where e.EMPLOYEE_ID in
    <foreach collection="array" item="employeeId" index="index"
        open="(" close=")" separator=",">
        #{employeeId}
    </foreach>
</select>

<!--Map:不單單forech中的collection屬性是map.key,其它所有屬性都是map.key,比如下面的departmentId -->
<select id="getEmployeesMapParams" resultType="Employees">
    select *
    from EMPLOYEES e
    <where>
        <if test="departmentId!=null and departmentId!=''">
            e.DEPARTMENT_ID=#{departmentId}
        </if>
        <if test="employeeIdsArray!=null and employeeIdsArray.length!=0">
            AND e.EMPLOYEE_ID in
            <foreach collection="employeeIdsArray" item="employeeId"
                index="index" open="(" close=")" separator=",">
                #{employeeId}
            </foreach>
        </if>
    </where>
</select>

Mapper類:
public interface EmployeesMapper {

List<Employees> getEmployeesListParams(List<String> employeeIds);

List<Employees> getEmployeesArrayParams(String[] employeeIds);

List<Employees> getEmployeesMapParams(Map<String,Object> params);

}

根據數組批量查詢
List selectPrivilegeByIds(@Param(“privilegeIds”) Integer[] privilegeIds);

<select id="selectPrivilegeByIds" resultMap="BaseResultMap" >
 select 
  <include refid="Base_Column_List" />
  from diary_privilege
 where id in
  <foreach collection="array" item="item" index="index" open="(" separator="," close=")">
              #{item}
   </foreach>
</select>

根據集合插入批量插入

int insertEmployeeRole(EmployeeRoleVo employeeRole);(EmployeeRoleVo中包含List<Role> roleList)
 
  <insert id="insertEmployeeRole" parameterType="com.jimmy.demo.vo.EmployeeRoleVo" >
  insert into diary_employee_role (employeeId,roleId)
  values
  <foreach collection="roleList" item="item" index="index" separator="," >  
      (#{employee.eid},#{item.id})  
  </foreach>  
</insert>

報錯了:
invalid comparison: java.util.Arrays$ArrayList and java.lang.String
犯了一個低級的錯誤,在傳集合類型的參數時,把他當成字符串處理了,導致報類型轉換的錯誤
在這裏插入圖片描述

解決辦法:把 and nsrsbh!=’ ’ 刪掉就行了

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章