【Mybatis/Oracle】如何在Mybatis的Mapper中撰写一个向Oracle某表批量插入数据的函数
本文例程下载:https://files.cnblogs.com/files/heyang78/myBank_210905_1611.rar
本文涉及到的Oracle版本:11.2.0.1.0,SpringBoot版本:2.5.4,MyBatis选择SpringBoot提供的2.2.0,不保证下例在其它版本中运转正常。
下面是正文:
如果Oracle中有某表Student,它仅包括id和name两个字段,那么向其中批量插值的SQL语句应当这样写:
Insert all Insert into student(id,name) values ('1','XXX') Insert into student(id,name) values ('2','XXX') Insert into student(id,name) values ('3','XXX') .... Insert into student(id,name) values ('n','XXX') select * from dual
这个语句实际上就是在多个单条插入语句前面放了一句insert all,后面放了一句 select * from dual。
由于是一次性推送到DB端执行,所以执行效率比单条运行n次高一截。
需要注意的是n不是想写多少就多少的,这与Oracle版本和机器性能有关,在我的T440p里,n可以取两百多一点,但超不过300,否则程序运行时可能报错。
再往下就是把这一整句SQL在Mapper里写出来的过程。
由于接口类没法写函数体,我们需要把接口函数引向真正的类函数:
Mapper类:
@Mapper public interface StudentMapper { ...... @SelectProvider(type=StudentSql.class,method="bunchInsert") void bunchInsert(int count); }
StudentSQL类:
package com.hy.mybank.mapper; public class StudentSql { // 利用数据库的批量插入语法,一次性插入批量记录到Student表 public String bunchInsert(int count) { StringBuilder sb=new StringBuilder(); sb.append("INSERT ALL "); for(int i=0;i<count;i++) { sb.append(" INTO student(id, name) values('"+i+"','"+i+"')"); } sb.append("select * from dual"); String sql = sb.toString(); return sql; } }
很明显,bunchInsert函数主要就是在拼装我们在一开头提到的SQL语句。
之后在测试函数里调用
@Test void bunchInsert() { stuMapper.bunchInsert(202); }
最后看看DB的情况:
Expected=Actual,看来目的达成了。
-END-
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
2020-09-05 如何手动合并ts视频文件
2019-09-05 Sql语法树示例 select username, ismale from userinfo where age > 20 and level > 5 and 1 = 1
2019-09-05 【高中数学/基本不等式】当x是正实数时,求函数f(x)=x/(1+x^2)的最大值?
2019-09-05 【Canvas与纹饰】环形小蜜蜂纹饰
2019-09-05 【高中数学/基本不等式】已知:x,y皆为正实数,且满足2x+y=1 求:1/x+1/y的最小值?
2019-09-05 [Tool]截屏利器FSCapture7.6下载
2019-09-05 [eclipse]如何修改Eclipse编辑器的字体