springMVC 事务实现

Spring 为事务管理提供了丰富的功能支持。Spring 事务管理分为编程式和声明式的两种方式。编程式事务指的是通过编码方式实现事务;声明式事务基于 AOP,将具体业务逻辑与事务处理解耦。声明式事务管理使业务代码逻辑不受污染, 因此在实际使用中声明式事务用的比较多。声明式事务有两种方式,一种是在配置文件(xml)中做相关的事务规则声明,另一种是基于 @Transactional 注解的方式。注释配置是目前流行的使用方式。

@Transactional 注解管理事务的实现步骤

分为两步。第一步,在 xml 配置文件中添加 事务配置信息。除了用配置文件的方式,@EnableTransactionManagement 注解也可以启用事务管理功能。这里以简单的 DataSourceTransactionManager 为例。

在 xml 配置中的事务配置信息





 

第二步,将@Transactional 注解添加到合适的方法上,并设置合适的属性信息。

事务回滚会有类似的debug日志:

2020-07-13 11:02:08.265 [http-nio-8080-exec-10] DEBUG-Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@32968a19]
2020-07-13 11:02:08.265 [http-nio-8080-exec-10] DEBUG-Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@32968a19]
2020-07-13 11:02:08.265 [http-nio-8080-exec-10] DEBUG-Initiating transaction rollback
2020-07-13 11:02:08.265 [http-nio-8080-exec-10] DEBUG-Rolling back JDBC transaction on Connection [com.mysql.cj.jdbc.ConnectionImpl@1281941f]
2020-07-13 11:02:08.314 [http-nio-8080-exec-10] DEBUG-Releasing JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@1281941f] after transaction
2020-07-13 11:02:08.314 [http-nio-8080-exec-10] DEBUG-Returning JDBC Connection to DataSource

 

事务不回滚情况按以下排查:

1.数据库引擎为InnoDb,Mylsam不支持事务。

2.添加@Transactional 注解的方法,必须是public的

3.添加@Transactional 注解的方法所在的类应注解为@Service或@Component

4.需要调用@Transactional 注解的方法的类,应在此类的外面,应注意事务的内部调用问题。

5.注意@Transactional 注解的的异常范围:rollbackFor的属性=Exception.class

 

参考博客:https://developer.ibm.com/zh/articles/j-master-spring-transactional-use/#

事务的自调用问题可参考:https://www.jianshu.com/p/befc2d73e487

你可能感兴趣的:(SpringMvc)