博客
关于我
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 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>