在MyBatis中执行批处理可以使用SqlRunner类的batch()方法。以下是一个示例代码:
SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH);
SqlRunner sqlRunner = new SqlRunner(sqlSession);
try {
// 开始批处理
sqlRunner.batch(sqlSession -> {
// 执行批处理的SQL语句
sqlSession.insert("insertUser", user1);
sqlSession.insert("insertUser", user2);
sqlSession.insert("insertUser", user3);
});
// 提交事务
sqlSession.commit();
} catch (Exception e) {
// 发生异常时回滚事务
sqlSession.rollback();
} finally {
sqlSession.close();
}
在上面的代码中,我们首先通过SqlSessionFactory打开一个新的SqlSession,并指定ExecutorType为BATCH。然后创建一个SqlRunner对象,并在batch()方法中执行需要批处理的SQL语句。最后在try-catch-finally块中进行事务的提交和回滚操作。
需要注意的是,在执行批处理之前必须手动开启事务,并在执行完成后手动提交或回滚事务。同时,在执行批处理时,所有SQL语句将会一起提交,所以务必确保所有SQL语句都能够成功执行,否则需要手动回滚事务。