zoukankan      html  css  js  c++  java
  • Spring 之注解事务 @Transactional

    众所周知的ACID属性: 
    原子性(atomicity)、一致性(consistency)、隔离性(isolation)以及持久性(durability)。我们无法控制一致性、原子性以及持久性,但可以控制超时,设置事务的只读性以指定隔离级别。 
    Spring在TransactionDefinition接口封装了所有这些设置。

    Spring在TransactionDefinition接口中规定了7种类型的事务传播行为,

    它们规定了事务方法和事务方法发生嵌套调用时事务如何进行传播:

    事务传播行为类型

    事务传播行为类型

    说明

    PROPAGATION_REQUIRED

    如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。这是最常见的选择。

    PROPAGATION_SUPPORTS

    支持当前事务,如果当前没有事务,就以非事务方式执行。

    PROPAGATION_MANDATORY

    使用当前的事务,如果当前没有事务,就抛出异常。

    PROPAGATION_REQUIRES_NEW

    新建事务,如果当前存在事务,把当前事务挂起。

    PROPAGATION_NOT_SUPPORTED

    以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。

    PROPAGATION_NEVER

    以非事务方式执行,如果当前存在事务,则抛出异常。

    PROPAGATION_NESTED

    如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类 似的操作。

    spring 事务注解
    
    默认遇到throw new RuntimeException("...");会回滚
    需要捕获的throw new Exception("...");不会回滚
    
    // 指定回滚
    @Transactional(rollbackFor=Exception.class)
        public void methodName() {
           // 不会回滚
           throw new Exception("...");
        }
    //指定不回滚
    @Transactional(noRollbackFor=Exception.class)
        public ItimDaoImpl getItemDaoImpl() {
            // 会回滚
            throw new RuntimeException("注释");
        }
    
        // 如果有事务,那么加入事务,没有的话新建一个(不写的情况下)
        @Transactional(propagation=Propagation.REQUIRED)
        // 容器不为这个方法开启事务
        @Transactional(propagation=Propagation.NOT_SUPPORTED)
        // 不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
        @Transactional(propagation=Propagation.REQUIRES_NEW)
        // 必须在一个已有的事务中执行,否则抛出异常
        @Transactional(propagation=Propagation.MANDATORY)
        // 必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反)
        @Transactional(propagation=Propagation.NEVER)
        // 如果其他bean调用这个方法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.
        @Transactional(propagation=Propagation.SUPPORTS)
        
        /*
        public void methodName(){
           // 本类的修改方法 1
           update();
           // 调用其他类的修改方法
           otherBean.update();
           // 本类的修改方法 2
           update();
        }
        other失败了不会影响 本类的修改提交成功
        本类update的失败,other也失败
        */
    @Transactional(propagation=Propagation.NESTED)
    // readOnly=true只读,能插入,但不能更新,删除
    @Transactional (propagation = Propagation.REQUIRED,readOnly=true)
    // 设置超时时间
    @Transactional (propagation = Propagation.REQUIRED,timeout=30)
    // 设置数据库隔离级别
    @Transactional (propagation = Propagation.REQUIRED,isolation=Isolation.DEFAULT)

    事务隔离级别: 
    隔离级别 说明 
    ISOLATION_DEFAULT 默认级别(对大多数数据库来说就是ISOLATION_READ_COMMITTED) 
    ISOLATION_READ_UNCOMMITTED 最低的隔离级别。事实上我们不应该隔离级别,因为在事务完成前,其他事务可以看到该事务所修改的数据。而在其他事务提交前,该事务也可以看到其他事务所做的修改。 
    ISOLATION_READ_COMMITTED 大多数数据库的默认级别。在事务完成前,其他事务无法看到该事务所修改的数据。遗憾的是,在该事务提交后,你就可以查看其他事务插入活更新的数据。这意味 着在事务的不同点上,如果其他事务修改数据,你会看到不同的数据。 
    ISOLATION_REPEATABLE_READ 该隔离级别确保如果在事务中查询了某个数据集,你至少还能再次查询到相同的数据集,即使其他事务修改了所查询的数据。然而如果其他事务插入了新数据,你就可以查询到该新插入的数据。 
    ISOLATION_SERIALIZABLE 代价最大、可靠性最高的隔离级别,所有的事务都是俺顺序一个接一个的执行。

    爱生活,更爱给我带来生活的人
  • 相关阅读:
    URAL 1998 The old Padawan 二分
    URAL 1997 Those are not the droids you're looking for 二分图最大匹配
    URAL 1995 Illegal spices 贪心构造
    URAL 1993 This cheeseburger you don't need 模拟题
    URAL 1992 CVS
    URAL 1991 The battle near the swamp 水题
    Codeforces Beta Round #92 (Div. 1 Only) A. Prime Permutation 暴力
    Codeforces Beta Round #7 D. Palindrome Degree hash
    Codeforces Beta Round #7 C. Line Exgcd
    Codeforces Beta Round #7 B. Memory Manager 模拟题
  • 原文地址:https://www.cnblogs.com/chenyq/p/5815667.html
Copyright © 2011-2022 走看看