mybatis事务总结

在 MyBatis 中有两种事务管理器类型(也就是 type=”[JDBC|MANAGED]”):
  JDBC –  这个配置直接简单使用了JDBC 的提交和回滚设置。它依赖于从
到的连接来管理事务范围。 
  MANAGED –  这个配置几乎没做什么。它从来不提交或回滚一个连接。
容器来管理事务的整个生命周期(比如 Spring 或 JEE应用服务器的上下文
情况下它会关闭连接。然而一些容器并不希望这样,因此如果你需要从连
它,将 closeConnection 属性设置为 false。例如: 
<transactionManager type="MANAGED"> 
<property name="closeConnection" value="false"/> 
</transactionManager> 
这两种事务管理器都不需要任何属性。然而它们都是类型别名,要替换使用它
放置将你自己的类的完全限定名或类型别名,它们引用了你对 TransacFactory 接
。 
public interface TransactionFactory { 
void setProperties(Properties props); 
Transaction newTransaction(Connection conn, boolean autoC

任何在 XML 中配置的属性在实例化之后将会被传递给 setProperties()方法。你
要创建一个事务接口的实现,这个接口也很简单: 
public interface Transaction { 
Connection getConnection(); 
void commit() throws SQLException; 
void rollback() throws SQLException; 
void close() throws SQLException; 

使用这两个接口,你可以完全自定义 MyBatis 对事务的处理。 


sessionFactoryopenSession多个重载方法中有以下两个方法:

SqlSession openSession()
SqlSession openSession(boolean autoCommit)

不带参数的openSession()方法默认不开启autoCommit。openSession(boolean autoCommit)根据参数是true还是false来判断是否开启autoCommit。如果没有开启autoCommit,那么在insert、update、delete操作后,需要显式地调用commit()方法;如果开启了autoCommit,那么每个执行的sql语句都被看作一个事务来处理,且不需要显式地调用commit()方法。


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值