Mybatis里面实现多条语句
通常用在删除主表信息同时删除子表信息。如果利用多次Dao进行执行sql,程序就写起来麻烦并且阅读难度会提升。
(删除income表中的信息,同时删除子表income_detail表中的相关信息)
delete from income_detail where income_id=#{id};
delete from income where id=#{id};
或者是批量更新,比如利用foreach批量update多条数据。
<update id="update">
<foreach collection="xxList" item="item" index="index" open="" close="" separator=";">
update t_xxx
<set>
xxx = #{item.xxx}
</set>
where id = #{item.id}
</foreach>
</update>
这些语句的类似点在于都是在mybatis中带有分号的多条sql。而直接执行又会报错,所以我们需要在jdbc连接中加上allowMultiQueries参数,设置为true。
<property name="url" value="jdbc:mysql://localhost:3306/amoeba?characterEncoding=UTF-8&allowMultiQueries=true"/>
jdbc.url=jdbc:mysql://localhost:3306/amoeba?characterEncoding=UTF-8&allowMultiQueries=true