博客
关于我
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中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>