mybatis中使用批量操作以及ssm整合时使用数据库的批量数据库
以前一直使用的是<c:foreach>标签取出集合中的每一个要插入的元素然后依次进行批量操作的,但是后来仔细看了看后台打印的信息后发现这种批量操作的方式效率很低,于是在网上搜索了一番,偶然发现可以使用更加快捷简便的方式进行批量的操作。1.首先仅仅在mybatis框架中执行批量操作这个其实非常简单,只需要在创建openSession的时候在调用openSession()方
以前一直使用的是<c:foreach>标签取出集合中的每一个要插入的元素然后依次进行批量操作的,但是后来仔细看了看后台打印的信息后发现这种批量操作的方式效率很低,于是在网上搜索了一番,偶然发现可以使用更加快捷简便的方式进行批量的操作。
1.首先仅仅在mybatis框架中执行批量操作
这个其实非常简单,只需要在创建openSession的时候在调用openSession()方法的时候在该方法中传入一个参数:ExecutorType.BATCH就可以进行批量的操作。假如批量插入1000条数据,这种情况下,sql语句只预编译一次,参数构建1000。
如果不使用该方式,假如批量插入1000条数据,那么sql语句会预编译1000次,参数构建1000次,效率会明显降低很多。
@Test
public void testBetch() throws Exception{
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
//实现批量操作,需要在openSession方法中传入参数:ExecutorType.BATCH
SqlSession openSession = sqlSessionFactory.openSession(ExecutorType.BATCH); //通过sqlSessionFactory取得SqlSession对象
try {
EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
long startTime = System.currentTimeMillis();
//批量插入1000条数据
for(int i = 0;i < 1000;i++) {
mapper.doInsert(new Employee(UUID.randomUUID().toString().substring(1, 5),"demo@edu.com","1"));
}
openSession.commit(); //手动向数据库提交
long endTime = System.currentTimeMillis();
System.out.println("总计耗时:" + (endTime - startTime));
} catch (Exception e) {
e.printStackTrace();
}finally {
openSession.close();
}
}
2.在ssm整合的时候使用批量操作。
首先在spring的配置文件中,配置相应的可以执行批量操作的sqlSession的bean,该bean的class=“org.mybatis.spring.SqlSessionFactoryBean”
然后再设置该bean的两个构造参数即可完成配置文件的编写。
<!-- 配置一个可以进行批量执行的sqlSession -->
<bean id = "sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<!--ref:引入关联的sqlSessionFactory-->
<constructor-arg name="sqlSessionFactory" ref="sqlSessionFactoryBean"></constructor-arg>
<!--设置值value为支持批量操作-->
<constructor-arg name="executorType" value="BATCH"></constructor-arg>
</bean>
再需要执行批量操作的地方(即services层),只需要自动注入该sqlSession,然后利用该sqlSession调用getMapper(mapper.class)方法,即可获得对应的mapper对象,最后通过mapper对象调用响应的执行方法进行批量操作。
@Service
public class EmployeeService {
@Autowired
EmployeeMapper employeeMapper;
@Autowired
SqlSession sqlSession;
public void doInsert(List<Employee> emps) {
//使用可以执行批量操作的sqlSession,得到mapper对象
EmployeeMapper mapper = sqlSession.getMapper(EmployeeMapper.class);
//调用批量操作方法
mapper.doInsert(emps);
}
}
批量操作完成,查看批量操作的总耗时,明显比之前少了很多。
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐



所有评论(0)