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

以前一直使用的是标签取出集合中的每一个要插入的元素然后依次进行批量操作的,但是后来仔细看了看后台打印的信息后发现这种批量操作的方式效率很低,于是在网上搜索了一番,偶然发现可以使用更加快捷简便的方式进行批量的操作。

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),"[email protected]","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的两个构造参数即可完成配置文件的编写。


	
		
        
		
        
	

再需要执行批量操作的地方(即services层),只需要自动注入该sqlSession,然后利用该sqlSession调用getMapper(mapper.class)方法,即可获得对应的mapper对象,最后通过mapper对象调用响应的执行方法进行批量操作。

@Service
public class EmployeeService {
	
	@Autowired
	EmployeeMapper employeeMapper;
	
	@Autowired
	SqlSession sqlSession;
	
	public void doInsert(List emps) {
		//使用可以执行批量操作的sqlSession,得到mapper对象
		EmployeeMapper mapper = sqlSession.getMapper(EmployeeMapper.class);
		//调用批量操作方法
		mapper.doInsert(emps);
	}

}

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

 

 

你可能感兴趣的:(SSM框架)