学习记录

来源:互联网 发布:multisim少数据库 编辑:程序博客网 时间:2024/06/05 22:07

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

 

 

0 0
原创粉丝点击