学习记录 - TransactionDefinition

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一样

 

 

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值