以前一直使用的是<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);
}
}
批量操作完成,查看批量操作的总耗时,明显比之前少了很多。
本文介绍如何在MyBatis框架中使用批量操作提高数据库插入效率。通过在创建SqlSession时传入ExecutorType.BATCH参数,使SQL预编译一次即可执行多次参数构建,显著提升性能。
1482

被折叠的 条评论
为什么被折叠?



