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

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

前言


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


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

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

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

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

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

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


相关文章
|
8天前
|
XML Java 关系型数据库
@Transactional注解的失效场景
@Transactional注解的失效场景
64 1
|
8天前
|
Java 编译器 数据库
@Transactional中指定rollbackFor,弊端以及不能回滚的时候
@Transactional中指定rollbackFor,弊端以及不能回滚的时候
21 3
|
8天前
|
Java 数据库 Spring
Spring事务失效的场景详解
Spring事务失效的场景详解
42 0
|
8天前
|
Java 编译器 Spring
@transactional注解失效情况
@transactional注解失效情况
|
8天前
|
Java 数据库 Spring
@Transactional 失效场景介绍
【2月更文挑战第5天】
86 1
@Transactional 失效场景介绍
|
8天前
|
存储 Java 数据库连接
spring事务失效的几种情况与原因
spring事务失效的几种情况与原因
74 0
|
Java 数据库 Spring
@Transactional 注解失效问题
@Transactional 注解失效问题
|
存储 Oracle 安全
|
XML 缓存 Java
引起Spring事务失效的可能原因
引起Spring事务失效的可能原因
199 0
|
Java 数据库连接 数据库
Spring事务监听,为什么会出现事务失效?
Spring 在 4.2 版本之后提供了@TransactionlEventListener 注解,可以很方便地在事务提交后做一些处理,但是如果使用不当,或者没有正确理解其背后的运行逻辑,很容易踩坑甚至导致线上故障。 之前工作中就遇到了一个问题,在事务监听时,做了一些事务操作,但是这个事务并没有生效。 今天我们就来深入了解一下,这个问题是怎么产生的,又该如何解决。

热门文章

最新文章