mybatis事务总结

原创 2016年08月28日 19:22:13
在 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()方法。


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

mybatis事务与回滚例子 commit、rollback、autoCommit

1.在JDBC中,设置一次将当前所有操作为一次事务的方式是: conn.setAutoCommit( false ); 修改数据库遵从try-cath-finaly: try { ...

《深入理解mybatis原理》 MyBatis事务管理机制

MyBatis作为Java语言的数据库框架,对数据库的事务管理是其非常重要的一个方面。本文将讲述MyBatis的事务管理的实现机制。首先介绍MyBatis的事务Transaction的接口设计以及其不...

mybatis使用的一点小结:session运行模式及批量提交

mybatis的执行器有三种类型: ExecutorType.SIMPLE 这个类型不做特殊的事情,它只为每个语句创建一个PreparedStatement。 ExecutorT...

关于CMake编译生成的工程文件不能移动的问题

最近接触到了CMake编译,学习的过程中遇到了很多问题,现在记录一下,希望能帮助一些人少走弯路。     我是使用CMake在Windows平台下编译一个开源软件的源代码,编译成功后,我却发现生...

spring boot多任务配置

@SpringBootApplication @EnableScheduling public class Application { public static void main(S...

mybatis中commit和rollback使用不当造成事务泄露和锁超时问题总结

commit接口定义如下:   /**    * Flushes batch statements and commits database connection.    * Note th...
  • yfkscu
  • yfkscu
  • 2014年10月14日 18:53
  • 3973

事务管理、AOP总结以及MyBatis高级应用

一、事务(交易)管理 (1)容器类==集合框架==集合 (2)Web容器==Web服务器==Servlet容器==Servet引擎 (3)传播 ...

Spring/SpringMVC/MyBatis整合+事务回滚

  • 2016年02月24日 11:33
  • 25.61MB
  • 下载

MYsql单独使用mybatis事务处理的无法回滚问题

mysql有几种引擎,当使用InnoDB的时候,才可以进行事务处理,在navicat中如下设置: 1:进入表设计页面,选项按钮页面 2:修改数据库引擎为InnoDB 3:mybatis进...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:mybatis事务总结
举报原因:
原因补充:

(最多只允许输入30个字)