mybatis中使用批量操作以及ssm整合时使用数据库的批量数据库

本文介绍如何在MyBatis框架中使用批量操作提高数据库插入效率。通过在创建SqlSession时传入ExecutorType.BATCH参数,使SQL预编译一次即可执行多次参数构建,显著提升性能。

以前一直使用的是<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);
	}

}

批量操作完成,查看批量操作的总耗时,明显比之前少了很多。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值