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
就好了
例如我的數據庫連接配置就會變成