我是靠谱客的博主 光亮烧鹅,最近开发中收集的这篇文章主要介绍mybatis批量更新问题:在解决问题中不断突破自己,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

记一次mybatis批量更新bug修复过程

版本一

<update id="updateIsDelStatus" parameterType="java.util.List">
  <foreach collection="list" item="item" index="index" separator=";" close="" open="">
    update inp_record set IR_IsDel = -1
    where IR_ID = #{item,jdbcType=INTEGER}
  </foreach>
</update>

版本一在测试时报错,由于在和前端联调中,考虑到单词入参list的size并不是很大(使用in 建议控制在 size <= 10),临时采用版本二进行紧急修复

版本二

<update id="updateIsDelStatus" parameterType="java.util.List">
    update inp_record set IR_IsDel = -1
    where IR_ID in
  <foreach collection="list" item="item" index="index" separator="," close=")" open="(">
    #{item,jdbcType=INTEGER}
  </foreach>
</update>

问题已得到基本解决,但是感觉稀里糊涂的处理事情并不能解决问题,于是进行了深入研究得出Mybatis默认是只执行一条sql的,因此版本一的写法是执行了多条sql,因此会在第一句sql时就报错。

解决办法:

在jdbcurl路径中添加:allowMultiQueries=true

但是还是不建议使用多条sql同时执行,尽量根据实际业务场景来使用单条sql来实现业务逻辑。

 

最后

以上就是光亮烧鹅为你收集整理的mybatis批量更新问题:在解决问题中不断突破自己的全部内容,希望文章能够帮你解决mybatis批量更新问题:在解决问题中不断突破自己所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部