MyBatis配置允许批量插入或更新数据

MyBatis配置allowMultiQueries=true允许使用foreach标签批量插入或更新数据

执行update更新操作:

xml 复制代码
<!-- 批量更新 -->
    <update id="updateBatchByKey" parameterType="java.util.List">
        <foreach collection="list" item="item" index="index" separator=";">
            UPDATE order_main_product
            <set>
                <if test="item.factoryId != null">factory_id = #{item.factoryId},</if>
                <if test="item.factoryCode != null and item.factoryCode != ''">factory_code = #{item.factoryCode},</if>
                <if test="item.factoryName != null and item.factoryName != ''">factory_name = #{item.factoryName},</if>
                <if test="item.orderId != null">order_id = #{item.orderId},</if>
                <if test="item.parentId != null">parent_id = #{item.parentId},</if>
                <if test="item.shipmentAmount != null and item.shipmentAmount != ''">shipment_amount =
                    #{item.shipmentAmount},
                </if>
                ......
            </set>
            WHERE id = #{item.id}
        </foreach>
    </update>

执行报错:

sql 复制代码
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'UPDATE
	order_main_product
SET
	product_count = 1,
	delivery_time = '2024-08' at line 2

错误位置: line: 1

解决:更改jdbc配置,加上allowMultiQueries=true

yml 复制代码
url: jdbc:mysql://172.16.1.145:3306/new_crm?useUnicode=true&characterEncoding=utf8&allowMultiQueries=true&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8&rewriteBatchedStatements=true&allowPublicKeyRetrieval=true

在MySQL连接中设置allowMultiQueries=true允许在SQL语句后使用分号分隔,执行多个命令。

原因:

MyBatis默认情况下不允许批量插入或更新数据的原因是出于安全考虑。在许多情况下,数据的插入和更新都需要经过验证和控制,以确保数据的完整性和一致性。如果允许默认的批量操作,可能会导致不正确的数据插入或更新,从而影响应用程序的正常运行。

通过配置allowMultiQueries=true可以开启MyBatis的批量操作功能。这个配置项告诉MyBatis允许在单个数据库连接中执行多个SQL语句,从而实现批量插入或更新数据的功能。但是要注意,在开启批量操作之前,确保你已经了解并理解了可能引发的安全风险,并且在使用批量操作时要进行适当的验证和控制,以确保数据的完整性和安全性。

尽管 allowMultiQueries 可以用于某些情况下的方便性,但出于安全和性能的考虑,通常不建议在生产环境中启用它。

相关推荐
mask哥15 分钟前
详解mcp以及agen架构设计与实现
java·微服务·flink·大模型·ai agent·springai·mcp
Propeller34 分钟前
【Android】View 交互的事件处理机制
android·java
杨杨杨大侠37 分钟前
Atlas Mapper 教程系列 (5/10):集合映射与嵌套对象处理
java·开源·github
ERP老兵_冷溪虎山38 分钟前
Python/JS/Go/Java同步学习(第十三篇)四语言“字符串转码解码“对照表: 财务“小南“纸式转码术处理凭证乱码崩溃(附源码/截图/参数表/避坑指南)
java·后端·python
是2的10次方啊39 分钟前
如何设计10万QPS秒杀系统?缓存+消息队列+分布式锁架构实战
java
心灵宝贝40 分钟前
Tomcat Connectors 1.2.37 源码编译安装教程(mod_jk 详细步骤)
java·tomcat
杨杨杨大侠43 分钟前
Atlas Mapper 教程系列 (6/10):Spring Boot 集成与自动配置
java·开源·github
傻傻虎虎1 小时前
【Docker】容器端口暴露+镜像生成实战
java·docker·容器
练习时长一年1 小时前
搭建langchain4j+SpringBoot的Ai项目
java·spring boot·后端
九术沫1 小时前
装饰器模式在Spring中的案例
java·spring·装饰器模式