MybatisSpring编程式事务管理
需求:同时有多条修改数据库操作,当一条出错,所有回滚
1、mybatis事务处理(作用于持久层,即DAO)
/** * 事务工厂接口,产生新的事务 */ TransactionFactory transactionFactory = new JdbcTransactionFactory(); SqlSession session = sqlSessionFactory.openSession(); //newTransaction(Connection arg, boolean autoCommit); Transaction newTransaction = transactionFactory.newTransaction(session.getConnection(), false);
由 newTransaction处理commit(),rollback(),close()
参考资料:
在 MyBatis 中有两种事务管理器类型(也就是 type=”[JDBC|MANAGED]”):
?JDBC–这个配置直接简单使用了JDBC的提交和回滚设置。它依赖于从数据源得
到的连接来管理事务范围。
?MANAGED–这个配置几乎没做什么。它从来不提交或回滚一个连接。而它会让
容器来管理事务的整个生命周期(比如Spring或JEE应用服务器的上下文)。默认
情况下它会关闭连接。然而一些容器并不希望这样,因此如果你需要从连接中停止
它,将closeConnection属性设置为false。例如:
<transactionManagertype="MANAGED">
<propertyname="closeConnection"value="false"/>
</transactionManager>
这两种事务管理器都不需要任何属性。然而它们都是类型别名,要替换使用它们,你需
要放置将你自己的类的完全限定名或类型别名,它们引用了你对TransacFactory接口的实现
类。
publicinterfaceTransactionFactory{
voidsetProperties(Propertiesprops);
TransactionnewTransaction(Connectionconn,booleanautoCommit);
}
任何在XML中配置的属性在实例化之后将会被传递给setProperties()方法。你的实现类
需要创建一个事务接口的实现,这个接口也很简单:
publicinterfaceTransaction{
ConnectiongetConnection();
voidcommit()throwsSQLException;
voidrollback()throwsSQLException;
voidclose()throwsSQLException;
}
使用这两个接口,你可以完全自定义 MyBatis 对事务的处理2、spring事务处理(作用于控制层)
spring就比较麻烦,需要用到spring编程式事务管理(我们平时用的都是声明式事务管理),具体区别google
@Controller public class 控制类 { @Resource PlatformTransactionManager platformTransactionManager; public void unitDelJob(Map<String, Object> arguments) { DefaultTransactionDefinition def = new DefaultTransactionDefinition(); TransactionStatus status=platformTransactionManager.getTransaction(def); try { service层业务或DAO层业务,看你的框架; } catch (RuntimeException e) { platformTransactionManager.rollback(status); e.printStackTrace(); } finally { platformTransactionManager.commit(status); } } }
通过 platformTransactionManager管理事务;
这里用注解装配一下,就不自己写bean的,需要的话自己在spring装配一下吧!
欢迎指正!!!