Mybatis批量插入insert的三种实现方式

 更新时间:2026年03月30日 14:34:46   作者:Jason_520168  
本文介绍了在Oracle和MyBatis中进行批量插入的不同方式,包括Oracle的INSERT ALL和SELECT FROM DUAL方法,以及MyBatis的UNION ALL方法,并提醒读者这些是个人经验总结

前言

提示:在orcale和mybatis执行批量插入是不一样的。

方式1

oracle批量插入使用 insert all into table(…) values(…) into table(…) values(…) select 1 from dual;

<insert id="insertListBatch" parameterType="java.util.List" useGeneratedKeys="false">
        INSERT ALL
        <foreach item="item" index="index" collection="list">
        INTO student
        (
            ID,
            name,
            age,
            sex,
            CREATE_TIME
        ) VALUES
        (
            #{item.id, jdbcType=NUMERIC},
            #{item.name, jdbcType=VARCHAR},
            #{item.age, jdbcType=VARCHAR},
            #{item.sex, jdbcType=VARCHAR},
            #{item.createdTime, jdbcType=NUMERIC} 
        )
        </foreach>
        SELECT 1 FROM DUAL
    </insert>

方式2

insert into table(…) (select … from dual) union all (select … from dual)

<insert id="insertListBatch" parameterType="java.util.List" useGeneratedKeys="false">
        INSERT INTO T_APPLAUD
        (
            ID,
            name,
            age,
            sex,
            CREATE_TIME
        )
        <foreach item="item" index="index" collection="list" separator="union all">
        (
            SELECT 
                #{item.id},
                #{item.name},
                #{item.age},
                #{item.sex},
                #{item.createdTime} 
            FROM DUAL
        )
        </foreach>
    </insert>

方式3

mysq如下:

<insert id="insertListBatch" >
    insert into student ( id,name,age,sex,createdTime ) values
    <foreach collection="list" item="item" index="index" separator=",">
    	(null,#{item.name},#{item.age},#{item.sex},#{item.createdTime}
    </foreach>
</insert>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MyBatis中XML映射器的实现

    MyBatis中XML映射器的实现

    MyBatis的真正强大在于它的语句映射,映射器的XML文件就显得相对简单,本文主要介绍了MyBatis中XML映射器的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • 一文详解Spring中ResponseEntity包装器的使用

    一文详解Spring中ResponseEntity包装器的使用

    在 Spring 中,ResponseEntity 是 HTTP 响应的包装器,这篇文章主要为大家详细介绍了ResponseEntity包装器的使用,感兴趣的可以了解一下
    2025-02-02
  • springboot 自定义异常并捕获异常返给前端的实现代码

    springboot 自定义异常并捕获异常返给前端的实现代码

    在开发中,如果用try catch的方式,每个方法都需要单独实现,为了方便分类异常,返回给前端,采用了@ControllerAdvice注解和继承了RuntimeException的方式来实现,具体实现内容跟随小编一起看看吧
    2021-11-11
  • Java使用WeakHashMap实现缓存自动清理

    Java使用WeakHashMap实现缓存自动清理

    在 Java 中,内存管理是一个重要的话题,尤其是在涉及到缓存的实现时,如果缓存项不再被使用,我们希望它们能被自动清理,而不必手动删除,WeakHashMap 就是 Java 提供的一种用于缓存和内存管理的工具,本文将深入探讨如何利用 WeakHashMap 来实现缓存自动清理
    2025-01-01
  • java中的序列化解析

    java中的序列化解析

    这篇文章主要介绍了java中的序列化解析,为了将对象进行网络传输或者是持久化,我们需要将对象的状态信息转换为可以存储或者传输的形式,这个转换的过程就叫序列化,需要的朋友可以参考下
    2023-09-09
  • 通过Java Reflection实现编译时注解正确处理方法

    通过Java Reflection实现编译时注解正确处理方法

    Java注解是一种标记在JDK5及以后的版本中引入,用于Java语言中向程序添加元数据的方法,这篇文章主要介绍了通过Java Reflection实现编译时注解处理方法,需要的朋友可以参考下
    2023-06-06
  • logback如何去掉DubboMonitor烦人的INFO日志

    logback如何去掉DubboMonitor烦人的INFO日志

    这篇文章主要介绍了logback如何去掉DubboMonitor烦人的INFO日志方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java9 集合工厂方法解析

    Java9 集合工厂方法解析

    这篇文章主要介绍了Java9 集合工厂方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • Intellij IDEA命令行执行java无法加载主类解决方案

    Intellij IDEA命令行执行java无法加载主类解决方案

    这篇文章主要介绍了Intellij IDEA命令行执行java无法加载主类解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • MyBatis Spring集成完全指南(史上最全)

    MyBatis Spring集成完全指南(史上最全)

    MyBatis-Spring是一个库,用于无缝集成MyBatis和Spring框架,实现事务管理、自动创建Mapper和SqlSession、异常转换等功能,本文给大家介绍MyBatis Spring集成完全指南,感兴趣的朋友跟随小编一起看看吧
    2025-10-10

最新评论