【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-

posted @   逆火狂飙  阅读(413)  评论(0编辑  收藏  举报
编辑推荐:
· 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编辑器的字体
生当作人杰 死亦为鬼雄 至今思项羽 不肯过江东
点击右上角即可分享
微信分享提示