zoukankan      html  css  js  c++  java
  • spring事务传播行为与事务隔离等级

    propagation属性的传播行为:
    REQUIRED:指定当前方法必需在事务环境中运行,如果当前有事务环境就加入当前正在执行的事务环境,如果当前没有事务,就新建一个事务。这是默认值。 
    SUPPORTS:指定当前方法加入当前事务环境,如果当前没有事务,就以非事务方式执行。 
    MANDATORY:指定当前方法必须加入当前事务环境,如果当前没有事务,就抛出异常。 
    REQUIRES_NEW:指定当前方法总是会为自己发起一个新的事务,如果发现当前方法已运行在一个事务中,则原有事务被挂起,我自己创建一个属于自己的事务,直我自己这个方法commit结束,原先的事务才会恢复执行。 
    NOT_SUPPORTED:指定当前方法以非事务方式执行操作,如果当前存在事务,就把当前事务挂起,等我以非事务的状态运行完,再继续原来的事务。 
    NEVER:指定当前方法绝对不能在事务范围内执行,如果方法在某个事务范围内执行,容器就抛异常,只有没关联到事务,才正常执行。 
    NESTED:指定当前方法执行时,如果已经有一个事务存在,则运行在这个嵌套的事务中.如果当前环境没有运行的事务,就新建一个事务,并与父事务相互独立,这个事务拥有多个可以回滚的保证点。就是指我自己内部事务回滚不会对外部事务造成影响,只对DataSourceTransactionManager事务管理器起效。

    Isolation Level(事务隔离等级)

    DEFAULT:采用数据库默认隔离级别 
    SERIALIZABLE:最严格的级别,事务串行执行,资源消耗最大; 
    REPEATABLE_READ:保证了一个事务不会修改已经由另一个事务读取但未提交(回滚)的数据。避免了“脏读取”和“不可重复读取”的情况,但是带来了更多的性能损失。 
    READ_COMMITTED:大多数主流数据库的默认事务等级,保证了一个事务不会读到另一个并行事务已修改但未提交的数据,避免了“脏读取”。该级别适用于大多数系统。 
    READ_UNCOMMITTED:保证了读取过程中不会读取到非法数据。隔离级别在于处理多事务的并发问题。
    为什么事务要有Isolation Level这个属性?先回顾下数据库事务的知识: 
    第一类丢失更新(lost update):在完全未隔离事务的情况下,两个事物更新同一条数据资源,某一事物异常终止,回滚造成第一个完成的更新也同时丢失。 
    第二类丢失更新(second lost updates):是不可重复读的特殊情况,如果两个事务都读取同一行,然后两个都进行写操作,并提交,第一个事务所做的改变就会丢失。 
    脏读(dirty read):如果第二个事务查询到第一个事务还未提交的更新数据,形成脏读。因为第一个事务你还不知道是否提交,所以数据不一定是正确的。 
    虚读(phantom read):一个事务执行两次查询,第二次结果集包含第一次中没有或者某些行已被删除,造成两次结果不一致,只是另一个事务在这两次查询中间插入或者删除了数据造成的。 
    不可重复读(unrepeated read):一个事务两次读取同一行数据,结果得到不同状态结果,如中间正好另一个事务更新了该数据,两次结果相异,不可信任。

    常用事物配置
    <tx:advice id="txAdvice" transaction-manager="txManager"> 
    <tx:attributes> 
               <tx:method name="save*" propagation="REQUIRED" /> 
               <tx:method name="add*" propagation="REQUIRED" /> 
               <tx:method name="create*" propagation="REQUIRED" /> 
               <tx:method name="insert*" propagation="REQUIRED" /> 
               <tx:method name="update*" propagation="REQUIRED" /> 
               <tx:method name="merge*" propagation="REQUIRED" /> 
               <tx:method name="del*" propagation="REQUIRED" /> 
               <tx:method name="remove*" propagation="REQUIRED" /> 
               <tx:method name="put*" propagation="REQUIRED" /> 
               <tx:method name="get*" propagation="SUPPORTS" read-only="true" /> 
               <tx:method name="count*" propagation="SUPPORTS" read-only="true" /> 
               <tx:method name="find*" propagation="SUPPORTS" read-only="true" /> 
               <tx:method name="list*" propagation="SUPPORTS" read-only="true" /> 
               <tx:method name="*" propagation="SUPPORTS" read-only="true" /> 
               <tx:method name="batchSaveOrUpdate" propagation="REQUIRES_NEW" /> 
           </tx:attributes> 
    </tx:advice> 
    <aop:config> 
           <aop:pointcut id="txPointcut" expression="execution(* cn.javass..service.*.*(..))" /> 
           <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut" /> 
    </aop:config> 

    1. <!-- 最常用的配置 -->  
    2. <tx:advice id="txAdvice" transaction-manager="txManager">  
    3. <tx:attributes>  
    4.            <tx:method name="save*" propagation="REQUIRED" />  
    5.            <tx:method name="add*" propagation="REQUIRED" />  
    6.            <tx:method name="create*" propagation="REQUIRED" />  
    7.            <tx:method name="insert*" propagation="REQUIRED" />  
    8.            <tx:method name="update*" propagation="REQUIRED" />  
    9.            <tx:method name="merge*" propagation="REQUIRED" />  
    10.            <tx:method name="del*" propagation="REQUIRED" />  
    11.            <tx:method name="remove*" propagation="REQUIRED" />  
    12.            <tx:method name="put*" propagation="REQUIRED" />  
    13.            <tx:method name="get*" propagation="SUPPORTS" read-only="true" />  
    14.            <tx:method name="count*" propagation="SUPPORTS" read-only="true" />  
    15.            <tx:method name="find*" propagation="SUPPORTS" read-only="true" />  
    16.            <tx:method name="list*" propagation="SUPPORTS" read-only="true" />  
    17.            <tx:method name="*" propagation="SUPPORTS" read-only="true" />  
    18.            <tx:method name="batchSaveOrUpdate" propagation="REQUIRES_NEW" />  
    19.        </tx:attributes>  
    20. </tx:advice>  
    21. <aop:config>  
    22.        <aop:pointcut id="txPointcut" expression="execution(* cn.javass..service.*.*(..))" />  
    23.        <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut" />  
    24. </aop:config> 
    收藏文章数量从多到少与“把书读薄”是一个道理
  • 相关阅读:
    剑指offer编程题Java实现——面试题14调整数组顺序使奇数位于偶数之前
    剑指offer编程题Java实现——面试题13在O(1)时间内删除链表节点
    剑指offer编程题Java实现——面试题12相关题大数的加法、减法、乘法问题的实现
    剑指offer编程题Java实现——面试题12打印1到最大的n位数
    《深入理解JAVA虚拟机》——学习笔记
    剑指offer编程题Java实现——面试题11数值的整数次方
    剑指offer编程题Java实现——面试题10二进制中1的个数
    剑指offer编程题Java实现——面试题9斐波那契数列
    剑指offer编程题Java实现——面试题8旋转数组的最小数字
    mysql高可用集群——MHA架构
  • 原文地址:https://www.cnblogs.com/use-D/p/7696286.html
Copyright © 2011-2022 走看看