mybatis批量操做問題總結

一、mybatis接受list參數問題html

http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html#foreach裏有一段說明:java

寫道mysql

注意 你能夠傳遞一個 List 實例或者數組做爲參數對象傳給 MyBatis。當你這麼作的時 候,MyBatis 會自動將它包裝在一個 Map 中,用名稱在做爲鍵。List 實例將會以「list」 做爲鍵,而數組實例將會以「array」做爲鍵。git

由於我傳的參數只有一個,並且傳入的是一個List集合,因此mybatis會自動封裝成Map<"list",studentNameList>。在解析的時候會經過「list」做爲Map的key值去尋找。可是我在xml中卻聲明成studentNameList了,因此天然會報錯找不到。github

 

解決辦法:sql

第一種就是修改mapper.xml中foreach標籤內容,把studentNameList修改成list數組

  1. <if test="list != null">  
  2.     AND student_name in  
  3.     <foreach collection="list" item="item" open="(" separator="," close=")">  
  4.         #{item}   
  5.     </foreach>  
  6. </if> 

不過這種方式我我的不太建議,由於之後若是要擴展該方法,增長集合參數的時候,還得修改xml中的內容。mybatis

 

第二種方式,修改dao中的參數傳入方式,手動封裝成map,而後把map當參數傳進去app

Dao方法修改成:測試

  1. public int getStudentCount(List<String> studentNameList){  
  2.     //把參數手動封裝在Map中  
  3.     Map<String, Object> map = new HashMap<String, Object>();  
  4.     map.put("studentNameList", studentNameList);  
  5.     return super.count("getStudentCount", map);  
  6. }  

而後修改mapper.xml中的parameterType類型爲Map

  1. <!--注意下面的parameterType類型必須修改成Map類型,foreach中引用的List名稱不用改變-->  
  2. <select id="Student.getStudentCount" parameterType="java.util.Map" resultType="java.lang.Integer">  
  3.     <![CDATA[ 
  4.     SELECT 
  5.         COUNT(*) 
  6.     FROM 
  7.         t_student WHERE 1=1  
  8.     ]]>  
  9.     <if test="studentNameList != null">  
  10.         AND student_name in  
  11.         <foreach collection="studentNameList" item="item" open="(" separator="," close=")">  
  12.             #{item}   
  13.         </foreach>  
  14.     </if>  
  15. </select>  

修改完後,從新執行了一下測試用例,測試經過。

 

二、同時執行多條語句問題

<!-- 批量更新 -->
<update id="updatePL" parameterType = "java.util.List">
<foreach collection="list" item="item" index="idx" separator=";" >
UPDATE t_mortgage_applay 
<set> 
mortgage_contract_id = #{item.mortgageContractId},
applay_type = #{item.applayType},
start_time = #{item.startTime},
end_time = #{item.endTime},
status = #{item.status},
remarks = #{item.remarks},
update_by = #{item.updateBy.id},
update_date = #{item.updateDate},
organ_id = #{item.organId},
proc_ins_id = #{item.procInsId},
audit_type = #{item.auditType}
</set> 
WHERE id = #{item.id}
</foreach>
</update>

注:jdbc.url=jdbc:mysql://127.0.0.1:3306/fpd_qh_test?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true      須要&allowMultiQueries=true才能夠支持多條語句同時執行

相關文章
相關標籤/搜索