mybatis foreach update问题

<update id="updateList"  parameterType="java.util.List">
    <foreach collection="list" item="item">
        update message set isread=#{item.isread} where id = #{item.id};
    </foreach>
</update>

这样批量update时候,list只有一条的时候,正常,但是list多条数据的时候,到第二条的时候,会在id参数设值的时候多家一个单引号,为什么?没找到原因

clipboard.png

阅读 6.3k
2 个回答

注意你这个报错的最后一个引号是对应 near 后的引号,不是对应你的 sql 引号。

新手上路,请多包涵

如果运用了,<set></set>语法,来mysql的批量更新是要我们主动去设置的,需要在配置数据库连接地址中加上&allowMultiQueries=true
详情可参照https://www.jianshu.com/p/feb...

已验证

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题