博客
关于我
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分表后同结构不同名称表之间复制数据以及Update语句只更新日期加减不更改时间
查看>>
mySql分页Iimit优化
查看>>
MySQL分页查询
查看>>
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>
mysql初始密码错误问题
查看>>
MySQL删除数据几种情况以及是否释放磁盘空间【转】
查看>>
Mysql删除重复数据通用SQL
查看>>
mysql判断某一张表是否存在的sql语句以及方法
查看>>
mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
查看>>
mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
查看>>
mysql加强(3)~分组(统计)查询
查看>>
mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
查看>>