Mybatis如何实现一个高效的批量插入操作呢?
admin
2024-02-22 21:46:09
0

转自:

Mybatis如何实现一个高效的批量插入操作呢?

下文是笔者收集的MyBatis高效插入数据的示例分享,请大家参阅

MyBatis简介

我们都知道MyBatis是目前市面上使用比较多的一个持久层框架(SSM中的M),
MyBatis可以简化实体类的封装操作,MyBatis通过mapper.xml文件可实现数据库各中操作,详细请见Mybatis教程
那么MyBatis如何实现批量插入数据操作呢?下文将讲述具体的实现思路,如下所示:

方式一:使用MyBatis中的 foreach标签

借助foreach,在sql语句中实现一个迭代集合,
foreach标签拥有一下属性(item,index,collection,open,separator,close)
item:集合中每一个元素进行迭代时的别名
index:设置名称,用于表示在迭代过程中,每次迭代到的位置
open:设置语句开始符
separator:设置每次进行迭代之间使用的分隔符
close:设置迭代的结束符号

注意事项:必须指定collection属性,此属性可放入List,array,Map

例:
*Mapper.xml的定义如下:


INSERT INTO users(name,pwd)

SELECT #{item.name} as a, #{item.pwd} as b FROM DUAL


方式二:使用mybatis ExecutorType.BATCH

Mybatis中内置了3种ExecutorType有3种:

  1. simple,此模式下它为每个语句的执行创建一个新的预处理语句,单条提交sql
  2. REUSE,此模式是可重用执行器,重用对象是Statement(即该执行器会缓存同一个sql的Statement,省去Statement的重新创建,优化性能)(即会重用预处理语句)
  3. batch,此模式重复使用已经预处理的语句,并且批量执行所有更新语句,显然batch性能将更优
注意事项:Batch模式是最快捷的一张方式,但是需用户自定义主键
当然Hibernate中也有类似Batch的处理方式

例:

方式一 spring+mybatis 的

//获取 sqlsession
//注入原有的sqlSessionTemplate
@Autowired
private SqlSessionTemplate sqlSessionTemplate;// 新获取一个模式为BATCH,并自动提交为false的session
// 当自动提交设置为true,将无法控制提交的条数,改为最后统一提交,可能导致内存溢出(注意控制提交数量,如达到1000条提交一次)SqlSession session = sqlSessionTemplate.getSqlSessionFactory().openSession(ExecutorType.BATCH,false);
//通过新的session获取mapper
userMapper = session.getMapper(UserMapper.class);
int size = 10000;
try{
for(int i = 0; i < size; i++) {//生成实体类User user = new User();user.setName(String.valueOf(System.currentTimeMillis()));userMapper.insert(user);if(i % 1000 == 0 || i == size - 1) { //手动每1000个一提交,提交后无法回滚 session.commit();//清理缓存,防止溢出session.clearCache();}}
} catch (Exception e) {//没有提交的数据可以回滚session.rollback();
} finally{session.close();
}/*
使用mapper及sql别名:包名+类名
*/public void insertBatch(Map paramMap, List list) throws Exception {
// 新获取一个模式为BATCH,自动提交为false的session
// 如果自动提交设置为true,将无法控制提交的条数,改为最后统一提交,可能导致内存溢出
SqlSession session = sqlSessionTemplate.getSqlSessionFactory().openSession(ExecutorType.BATCH, false);
try {
if(null != list || list.size()>0){
int lsize=list.size();
for (int i = 0, n=list.size(); i < n; i++) {User user= list.get(i);
user.setIndate((String)paramMap.get("indate"));
user.setDatadate((String)paramMap.get("dataDate"));//数据归属时间 session.insert(“包名+类名", user);if ((i>0 && i % 1000 == 0) || i == lsize - 1) {//if语句的作用设置每1000个一提交,提交后无法回滚session.commit();// 清理缓存,防止溢出session.clearCache();}}
}
} catch (Exception e) {// 没有提交的数据可以回滚session.rollback();
e.printStackTrace();} finally {session.close();}
}

相关内容

热门资讯

安卓系统最强定位手机版,最强定... 你有没有想过,在茫茫人海中,如何让你的手机定位功能像侦探一样精准无误?今天,就让我带你一探究竟,揭秘...
安卓运行环境选哪个系统,And... 你有没有想过,你的安卓手机到底是在哪个运行环境下才能发挥出最佳性能呢?这可是个技术活儿,选对了系统,...
zui15系统是安卓系统吗,揭... 亲爱的读者,你是否曾好奇过,那些在手机上运行得风生水起的系统,它们究竟是不是安卓的呢?今天,就让我带...
ios系统和安卓系统权限区别,... 你有没有发现,无论是手机还是平板,我们用的最多的就是那些APP了。而这些APP,它们在手机里可是有着...
荣耀手环6安卓版系统,智能生活... 你有没有注意到,最近你的手腕上是不是多了一抹亮丽的色彩?没错,说的就是荣耀手环6安卓版系统!这款智能...
极品奴隶系统下载安卓版,体验独... 你有没有听说过那个超级火的“极品奴隶系统”安卓版?最近,这款游戏在朋友圈里可是炸开了锅,大家都说它好...
安卓手机苹果系统扣费,揭秘扣费... 你有没有遇到过这种情况?手机里突然多了一笔扣费,而且还是那种你完全没意识到的扣费?尤其是当你用的是安...
安卓系统智能电视刷机,焕新体验 亲爱的电视迷们,你是否曾为你的安卓智能电视的性能所困扰?是不是觉得它运行缓慢,功能受限?别担心,今天...
安卓系统无法安装applica... 最近是不是遇到了安卓系统无法安装application的烦恼?别急,让我来帮你一探究竟,解决这个让人...
怎么取消安卓系统锁屏,解锁锁屏... 手机锁屏功能虽然能保护我们的隐私,但有时候也会让人头疼,比如忘记密码或者想快速查看信息时。那么,怎么...
安卓系统高德怎么下载,轻松获取... 你有没有发现,现在手机上导航软件真是越来越方便了?尤其是安卓系统的用户,高德地图这款神器简直成了出行...
安卓系统的开源部分,开源代码背... 你知道吗?安卓系统,这个在我们手机上无处不在的小家伙,竟然有一部分是开源的!是不是觉得有点神奇?别急...
小米下载安卓13系统,畅享智能... 亲爱的手机控们,你是否已经迫不及待想要体验最新的操作系统呢?没错,我说的就是安卓13系统!而今天,我...
安卓系统如何设置拍月亮,捕捉夜... 月亮,那轮皎洁的夜空明珠,总是让人心生向往。你是否也想用你的安卓手机捕捉到它的美丽瞬间呢?别急,今天...
安卓v8以上系统,探索安卓V8... 你知道吗?最近手机界可是掀起了一股新潮流,那就是安卓V8以上系统。这可不是什么小打小闹,而是实实在在...
安卓系统兼容哪个版本好,哪个版... 你有没有想过,你的安卓手机到底兼容哪个版本的系统最好呢?这可是个技术活儿,得好好研究研究。别急,今天...
安卓平板安装linux桌面系统... 你有没有想过给你的安卓平板来个变身大法?没错,就是给它安装一个Linux桌面系统!想象原本只能刷刷剧...
安卓什么手机系统bug最少,揭... 你有没有发现,用安卓手机的时候,有时候会遇到一些小麻烦,比如系统突然卡顿,或者某个应用突然崩溃,真是...
手机软件安卓下载系统,解锁手机... 你有没有发现,现在的生活越来越离不开手机了?手机里装满了各种各样的软件,让我们的生活变得更加便捷。今...
微软系统和安卓系统的cad软件... 你有没有想过,为什么你的电脑里装的是微软系统,而朋友的手机上却是安卓系统?这背后其实隐藏着一场关于操...