Mybatis执行多条语句/批量更新

 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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值