MyBatis Oracle 批量插入数据

MyBatis Oracle 批量插入数据

系统:Win10

JDK:1.8.0_351

IDEA:2022.3.3

1.需求描述

在一次项目中实施过程中,后台需要将地区数据插入到数据库,数据大概三千条左右,本来直接使用循环遍历插入的方式,结果居然需要十几秒的时间,感觉速度太慢了,所以便想办法提高插入数据的速度,经过多番资料查询和验证,结果选定了一款实现方式,特此记录下来。

2.实现方案

数据:3208 条

需求:将数据插入到 Oracle 数据库

2.1 循环 insert 插入

最基础的就是使用 for 循环遍历 list 数据,一个个进行插入

java 代码

java 复制代码
...
 //循环插入
 StopWatch started = new StopWatch();
 started.start();//开始计时
 for (Region region : regions) {
     regionMapper.insert(region);
 }
 started.stop();//停止计时
 System.out.println("插入" + list.size() + "条数据耗时: " + started.getTime());
...

mapper 接口

java 复制代码
int insert(Region region);

xml 语句

xml 复制代码
<insert id="insert">
    insert into DATA_REGION(id, name, pid)
    values (#{id}, #{name}, #{pid})
</insert>

这里测试执行了 3 次,平均耗时:15160 ms

2.2 insert all 插入

这里主要使用的 Oracle 的 INSERT ALL 语法

sql 复制代码
INSERT ALL
    INTO table_name(col1,col2,col3) VALUES(val1,val2, val3)
    INTO table_name(col1,col2,col3) VALUES(val4,val5, val6)
    INTO table_name(col1,col2,col3) VALUES(val7,val8, val9)
Subquery;

该方法用来批量向数据库中插入数据所用的

java 代码

java 复制代码
...
//insert all 插入
StopWatch started = new StopWatch();
started.start();//开始计时
regionMapper.insertAll(regions);
started.stop();//停止计时
System.out.println("插入" + list.size() + "条数据耗时: " + started.getTime());
...

mapper 接口

java 复制代码
int insertAll(List<Region> list);

xml 语句

xml 复制代码
<insert id="insertAll">
    insert all
    <foreach collection="list" item="item" index="index">
        into DATA_REGION(id, name, pid) VALUES (#{item.id},#{item.name},#{item.pid})
    </foreach>
    select 1 from dual
</insert>

这里测试执行了 3 次,平均耗时:8171 ms

2.3 insert union all 插入

这里是使用 union all 先将各个对象的值查询到一起再批量插入到表中

java 代码

java 复制代码
...
//batchInsert
StopWatch started = new StopWatch();
started.start();//开始计时
regionMapper.batchInsert(regions);
started.stop();//停止计时
System.out.println("插入" + list.size() + "条数据耗时: " + started.getTime());
...

mapper 接口

java 复制代码
int batchInsert(List<Region> list);

xml 语句

xml 复制代码
<insert id="batchInsert">
    insert into DATA_REGION(id, name, pid)
    <foreach collection="list" item="item" index="index" separator="union all">
        (
        select #{item.id},#{item.name},#{item.pid} from dual
        )
    </foreach>
</insert>

这里测试执行了 3 次,平均耗时:2619 ms

3.分析总结

根据上面的三次测试,我们可以得出如下表格

# 循环 insert 插入 insert all 插入 insert union all 插入
平均耗时 15.16s 8.17s 2.62s

所以我最后决定采用第三种方法,不过我这里数据量只有 3000 多条,如果数据量更大,可能要再测试看看。

后续看看还有没有更好的实现方案,如果找到我再添加到文章末尾。

相关推荐
SeaTunnel几秒前
实测有效|用 SeaTunnel 免费实现 MySQL→Oracle 实时同步,步骤超细
数据库·mysql·oracle·开源·seatunnel·数据同步·连接器
Mr.朱鹏2 分钟前
ShardingJDBC实战指南
java·jvm·数据库·spring·分库分表·shardingjdbc·shardingshere
学习OK呀3 分钟前
从 java8 升级 java17 的调整
java·后端
咔咔一顿操作4 分钟前
MySQL 事务管理与锁机制:解决并发场景下的数据一致性问题
java·数据库·mysql
渣哥10 分钟前
其实我不是很想和 Hashtable 说再见:一次跟“古董” HashMap 探险的的碎碎念
java
星梦清河18 分钟前
宋红康 JVM 笔记 Day16|垃圾回收相关概念
java·jvm·笔记
月阳羊37 分钟前
【硬件-笔试面试题-81】硬件/电子工程师,笔试面试题(知识点:详细讲讲同步时钟与异步时钟通信)
java·经验分享·单片机·嵌入式硬件·面试
麦兜*40 分钟前
MongoDB 备份与恢复终极指南:mongodump 和 mongorestore 深度实战
java·数据库·spring boot·mongodb·spring
长安——归故李1 小时前
【modbus学习】
java·c语言·c++·学习·算法·c#
许苑向上1 小时前
Spring Boot 的注解是如何生效的
java·spring boot·后端