博客
关于我
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: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>