在实际项目开发中经常出现需要批量更新数据的问题,由于批量更新存在多种方式(比如先查询,再删除,之后批量插入),这里我们就只讨论update语句的方式。
1. 条件不同,修改结果相同
例如:根据id来更新多条数据的状态
public interface Mapper {
void batchUpdate(@Param("list") List<Integer> list);
}
<select id="batchUpdate" parameterType="java.util.List">
update staff
set status = 0
where id in
<foreach collection="list" item="item" index="index" open="(" separator="," close=")" >
#{item}
</foreach>
</select>
2. 条件不同,修改结果也不同
上面的那种方式肯定不能满足我们的所有业务需求的,所以就有了一条执行语句可以执行多条子sql的方式。
public interface Mapper {
void batchUpdate(@Param("list") List<Map<?,?> list);
}
<update id="batchUpdate" parameterType="java.util.List" >
<foreach collection="list" item="item" index="index" separator=";">
UPDATE staff set count = #{item.count} , code = #{item.code} , invalid_time = #{item.time} WHERE id = #{item.id}
</foreach>
</update>
上面的SQL语句,红色部分separator=“;”,是重点。一行SQL语句中执行多个子SQL的时候(比如这里,MySQL默认是用分号最为一个语句的结束),会出问题。
在spring.datasource.url后加上allowMultiQueries=true
如:jdbc:mysql://localhost:3306/test?allowMultiQueries=true