博客
关于我
MyBatis事务|Spring管理MyBatis事务
阅读量:339 次
发布时间:2019-03-04

本文共 1901 字,大约阅读时间需要 6 分钟。

在原生MySQL命令中,或是在IBatis中,你可能会发现有startTransaction()之类的API提供出来给编程人员使用,而在MyBatis中,是没有这样的API的,MyBatis将这个操作集成到openSession()中了:

public interface SqlSessionFactory {	SqlSession openSession()	SqlSession openSession(boolean autoCommit)	SqlSession openSession(Connection connection)	SqlSession openSession(TransactionIsolationLevel level)	SqlSession openSession(ExecutorType execType,TransactionIsolationLevel level)	SqlSession openSession(ExecutorType execType)	SqlSession openSession(ExecutorType execType, boolean autoCommit)	SqlSession openSession(ExecutorType execType, Connection connection)	Configuration getConfiguration();}

默认的 openSession()方法没有参数,它会创建有如下特性的 SqlSession: 

• 会开启一个事务(也就是不自动提交) 
• 连接对象会从由活动环境配置的数据源实例中得到。 
• 事务隔离级别将会使用驱动或数据源的默认设置。 
• 预处理语句不会被复用,也不会批量处理更新。 

所以就这样MyBatis中就看不到开启事务的API了,简化了编程的流程。那么MyBatis单独进行事务编程的逻辑就很明确了,和JDBC事务编程很类似,大致流程如下:

try {	sqlsession.commit();} catch (Exception e) {	sqlsession.rollback();}finally {	sqlsession.close();}

这种独立使用MyBatis使用的方式虽然少见,但还是要了解下,下面我们来说说Spring如何接管MyBatis事务的。

这里我们讲述的是依赖于MyBatis-Spring组件来管理事务,一个使用MyBatis-Spring的主要原因是它允许MyBatis参与到Spring的事务管理中。而不是给MyBatis创建一个新的特定的事务管理器,MyBatis-Spring 利用了存在于Spring 中的 DataSourceTransactionManager。要开启Spring的事务处理,在Spring配置文件中配置一个DataSourceTransactionManager即可:

然后就可以在程序中使用@Transactional或者AOP的方式使用事务了。使用的方式很简单,但是大家注意了,org.springframework.jdbc.datasource.DataSourceTransactionManager这个类是spring-jdbc包中的类,而且只需要注入一个DataSource实例,事务控制是Spring管理,sql执行工作是MyBatis在管理,一系列需要事务的sql如何达到事务执行的要求?需要保证的是Spring拿到的Connection和MyBatis拿到的Connection是同一个即可。先后的流程我们需要梳理一下,MyBatis在和Spring结合时,我们是配置了一个org.mybatis.spring.SqlSessionFactoryBean的,MyBatis都能通过这个类型拿到SqlSession实例,SqlSession中聚合了Executor,Executor中聚合Transaction,Transaction聚合了Connection,Connection就是事务的底层控制方式了,而Connection是出自于DataSource,,而Spring的org.springframework.jdbc.datasource.DataSourceTransactionManager也注入了DataSource,所以他们是通过DataSource来联系的,具体的就是操控了从DataSource获取的Connection。

转载地址:http://onzh.baihongyu.com/

你可能感兴趣的文章
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
查看>>
MySQL 快速创建千万级测试数据
查看>>
mysql 快速自增假数据, 新增假数据,mysql自增假数据
查看>>
MySql 手动执行主从备份
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>