mybatis的批量update操作寫法很簡單,如下:
public interface YourMapper extends BaseMapper<YourExt> { void updateBatch(@Param("pojos") Collection<YourExt> pojos); }
<update id="updateBatch" parameterType="java.util.Collection"> <foreach collection="pojos" item = "pojo" separator= ";" > update your_table t set pt.your_value = #{pojo.yourValue} where pt.id = #{pojo.id} </foreach> </update>
在執行過程中報異常,但是sql和參數直接在DB里執行是好的,原因是MySql默認不支持批量更新,需要開發人員主動設置,只需要在你的數據庫連接url后面加上
&allowMultiQueries=true
就好了
例如我的數據庫連接配置就會變成