学习记录 - TransactionDefinition

本文介绍了事务隔离级别的概念及其解决的安全问题,包括脏读、不可重复读及幻读,并详细解释了不同隔离级别的特点及适用场景。同时,文章还探讨了事务的传播行为,通过具体的常量值帮助理解在不同情况下事务的处理方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TransactionDefinition定义事务隔离级别

隔离级别是为了解决以下这些安全问题而提供的解决方案:

脏读:一个事务读取到了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的。

不可重复度:在同一个事务里,多次读取同一个数据返回的结果有所不同。

虚读/幻读:一个事务读取了几行记录后,另一个事务插入一些记录,幻读就发生了。再后来的查询中,第一个事务就会发现有些原来没有的记录。


表1列出了你可以使用的事务隔离级别,并说明了其他事务可以访问的当前事务变化。


表1 事务隔离级别

隔离级别说明
TransactionDefinition.ISOLATION_DEFAULTPlatformTransactionManager的默认隔离级别(对大多数数据库来说就是ISOLATION_ READ_COMMITTED)MySQL默认采用ISOLATION_REPEATABLE_READ,Oracle采用READ__COMMITTED级别。
TransactionDefinition.ISOLATION_READ_UNCOMMITTED最低的隔离级别。事实上我们不应该称其为隔离级别,因为在事务完成前,其他事务可以看到该事务所修改的数据。而在其他事务提交前,该事务也可以看到其他事务所做的修改。可能导致脏,幻,不可重复读
TransactionDefinition.ISOLATION_READ_COMMITTED大多数数据库的默认级别。在事务完成前,其他事务无法看到该事务所修改的数据。遗憾的是,在该事务提交后,你就可以查看其他事务插入或更新的数据。这意味着在事务的不同点上,如果其他事务修改了数据,你就会看到不同的数据。可防止脏读,但幻读和不可重复读仍可以发生。
TransactionDefinition.ISOLATION_REPEATABLE_READ比ISOLATION_READ_COMMITTED更严格,该隔离级别确保如果在事务中查询了某个数据集,你至少还能再次查询到相同的数据集,即使其他事务修改了所查询的数据。然而如果其他事务插入了新数据,你就可以查询到该新插入的数据。可防止脏读,不可重复读,但幻读仍可能发生。
TransactionDefinition. ISOLATION_SERIALIZABLE代价最大、可靠性最高的隔离级别,所有的事务都是按顺序一个接一个地执行。避免所有不安全读取。

选择合适的隔离级别对于保证数据的一致性非常重要,并且所作出的选择会对性能产生重大影响。最高的隔离级别TransactionDefinition.ISOLATION_SERIALIZABLE开销最大。


TransactionDefinition定义事务传播行为

getPropagationBehavior()方法指定了当代码请求一个新的事务时spring所做的事情。表2列出了这个方法的常量值。


表2 传播行为值

传播行为说明
TransactionDefinition.PROPAGATION_REQUIRED当前如果有事务,Spring就会使用该事务;否则会开始一个新事务
TransactionDefinition.PROPAGATION_SUPPORTS当前如果有事务,Spring就会使用该事务;否则不会开始一个新事务
TransactionDefinition.PROPAGATION_MANDATORY当前如果有事务,Spring就会使用该事务;否则会抛出异常
TransactionDefinition.PROPAGATION_REQUIRES_NEWSpring总是开始一个新事务。如果当前有事务,则该事务挂起
TransactionDefinition.PROPAGATION_NOT_SUPPORTEDSpring不会执行事务中的代码。代码总是在非事务环境下执行,如果当前有事务,则该事务挂起
TransactionDefinition. PROPAGATION_NEVER即使当前有事务,Spring也会在非事务环境下执行。如果当前有事务,则抛出异常
TransactionDefinition. PROPAGATION_NESTED如果当前有事务,则在嵌套事务中执行。如果没有,那么执行情况与Transaction- Definition.PROPAGATION_REQUIRED一样

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值