zoukankan      html  css  js  c++  java
  • spring 事务属性

    本文介绍spring事务的5个属性

      spring中,声明事务是通过事务属性来定义的。事务属性描述了事务策略如何应用到方法上事务属性包含5个方面:

    • 传播行为
    • 隔离级别
    • 回滚规则
    • 事务超时
    • 是否只读

      传播行为

      传播行为定义了客户端与被调用方法之间的事务边界,即传播规则回答了这样的一个问题,新的事务应该被启动还是挂起,或者方法是否要在事务环境中运行。7中传播规则:

    1. PROPAGATION_MANDATORY(强制传播):表示该方法必须在事务中运行,如果当前事务不存在,则会抛出一个异常
    2. PROPAGATION_NESTED(嵌套传播):表示如果当前存在一个事务,那么该方法就回在嵌套事务中运行,嵌套的事务可以独立于当前事务进行单独地提交或回滚,如果当前事务不存在,那么其行为与PROPAGATION_REQUIRED一样
    3. PROPAGATION_NEVER:(从不传播):表示当前方法不应该运行在事务上下文中,如果档期正有一个事务在运行,则会抛出异常
    4. PROPAGATION_NOT_SUPPORED(不支持传播):表示该方法不应该运行在事务中,如果存在当前事务,在该方法运行期间,当前事务将会被挂起
    5. PROPAGATION_REQUIRED(必要传播):表示当前事务必须运行在事务中,如果当前事务存在,方法将会在该事务中运行,否则,会启动一个新的事务
    6. PROPAGATION_REQUIRED_NEW(新建必要传播):表示当前方法必须运行在自己的事务当中(运行在一个新建的事务当中),如果当前存在事务,当前事务挂起 
    7. PROPAGATION_SUPPORT(支持事务):表示当前方法不需要事务上下文,但是如果存在当前事务的话,那么盖房会在这个事务中运行

      隔离界别

      隔离级别定义了一个事务可能受其他并发事务影响的程度。

      多个并发事务可能会导致一下问题:

    1. 脏读---脏读发生在一个事务独缺了冰一个事务改写但尚未提交的数据时,如果改写在稍后被回滚了,那么第一个事务获取的数据就是无效的。
    2. 不可重复读---不可重复读发生在一个事务执行相同的查询两次或两次以上,但是每次都得到不同的数据时,这通常是因为另一个并发事务在两次查询期间更新了数据。
    3. 幻读---幻读发生在一个事务读取了几行数据,接着另外一个事务插入了一些数据,在随后的查询中,第一格式就回发现多了一些原本不存在的记录。

      隔离规则:

    1. ISOLATION_DEFAULT:使用后端数据库默认的规则
    2. ISOLATION_READ_UNCOMMITTED:允许读取尚未提交的数据变更,可能会导致脏读,幻读或不可重复读
    3. ISOLATION_READ_COMMITTED:允许读取并发事务已经提交的数据,可以防止脏读,但是幻读或不可重复读仍有可能发生
    4. ISOLATION_REPEATABLE_READ:对同意字段的多次读取结果是一致的,除非数据是被本事务自己所修改,看阻止脏读和不可重复读,但幻读仍有可能发生
    5. ISOLATIOM_SERIALIZABLE:完全服从ACID的隔离级别,确保阻止脏读,不可重复读以及幻读,这是最慢的数据隔离级别

      是否只读

      如果事务只对后端的数据库进行读操作,数据库可以利用事务ID只读特性来进行一些特定的优化。通过将事务设置为只读,你就可以给数据库一个机会,让他应用它认为合适的优化措施。因为是否只读是在事务启动的时候由数据库实施的,所以只有对那些具备可能启动一个新事务的传播行为(PROPAGATION_REQUIRED,PROPAGATION_REQUIRED_NEW,PROPAGATION_NESTED)的方法来说,才有意义。

      事务超时

      为了使应用程序很好地运行,事务不能运行太长时间。因为超时时钟会在事务开始时启动,所以只有对那些具备可能启动一个新事务的传播行为(PROPAGATION_REQUIRED,PROPAGATION_REQUIRED_NEW,PROPAGATION_NESTED)的方法来说,才有意义。

      

      事务回滚

      事务回滚规则定义了哪些异常会导致事务回滚而哪些不会。默认情况下,事务只有在遇到运行时期异常才回滚,而在遇到检查型异常时不会回滚。

    具体看下XML配置

    <tx:annotation-driven /> 
    <tx:advice id="txAdvice" transactionmanager="transactionManager">
            <tx:attributes>
                <tx:method name="*" propagation="REQUIRED"/>
            </tx:attributes>
    </tx:advice>
    <aop:config expose-proxy="true" proxy-target-class="true">
            <!-- 只对业务逻辑层实施事务 -->
            <aop:pointcut id="txPointcut" expression="execution(* com.weiaigongdi.access..service..*+.*(..))"/>
            <aop:advisor id="txAdvisor" advice-ref="txAdvice" pointcut-ref="txPointcut"/>
    </aop:config>
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 
             <property name="dataSource" ref="ds1" /> 
    </bean> 
  • 相关阅读:
    leetcode 131. Palindrome Partitioning
    leetcode 526. Beautiful Arrangement
    poj 1852 Ants
    leetcode 1219. Path with Maximum Gold
    leetcode 66. Plus One
    leetcode 43. Multiply Strings
    pytorch中torch.narrow()函数
    pytorch中的torch.repeat()函数与numpy.tile()
    leetcode 1051. Height Checker
    leetcode 561. Array Partition I
  • 原文地址:https://www.cnblogs.com/gongdi/p/5026336.html
Copyright © 2011-2022 走看看