小记——为什么@Transactional会失效?

简介: 小记——为什么@Transactional会失效?

前言


在项目开发中很多场景会用到事务,合理运用事务会提升代码的健壮性,我的猿子同事曾经做过一个实验,同一个方法中同时执行两个数据库语句,每1000条中大概有三到四条会出现数据插入不一致的情况,在数据量大的情况下,这个比例非常恐怖。


在事务的使用中应该注意以下三点:

1、使用@Transactional的方法必须是public修饰的。

2、使用@Transactional的方法不能再同类的其他方法中调用。

3、使用@Transactional只会对运行时异常回滚,IOException、SQLException及我们自定义的异常不会触发回滚。

重点是第三条,许多时候我们会自定义一下exception,这时候如何保证事务回滚呢?如下:@Transactional(rollbackFor = Exception.class)

这样就会保证我们遇到任何异常都会事务回滚!


相关文章
|
3月前
|
XML Java 关系型数据库
@Transactional注解的失效场景
@Transactional注解的失效场景
81 1
|
3月前
|
Java 编译器 数据库
@Transactional中指定rollbackFor,弊端以及不能回滚的时候
@Transactional中指定rollbackFor,弊端以及不能回滚的时候
39 3
|
3月前
|
Java 数据库 Spring
Spring事务失效的场景详解
Spring事务失效的场景详解
72 0
|
3月前
|
Java 编译器 数据库
在事务注解@Transactional中指定rollbackFor
在事务注解@Transactional中指定rollbackFor
34 0
|
3月前
|
Java 编译器 Spring
@transactional注解失效情况
@transactional注解失效情况
|
3月前
|
Java 数据库 Spring
@Transactional 失效场景介绍
【2月更文挑战第5天】
238 1
@Transactional 失效场景介绍
|
3月前
|
存储 Java 数据库连接
spring事务失效的几种情况与原因
spring事务失效的几种情况与原因
93 0
|
Java 数据库 Spring
@Transactional 注解失效问题
@Transactional 注解失效问题
|
存储 Oracle 安全
|
XML 缓存 Java
引起Spring事务失效的可能原因
引起Spring事务失效的可能原因
220 0