zoukankan      html  css  js  c++  java
  • Spring中Transactional 的配置

    @Transactional(noRollbackFor=RuntimeException.class)方法事务说明
    @Transactional(RollbackFor=Exception.class)
    @Transactional(readOnly=true)
    @Transactional(timeout=100)
    @Transactional(isolation)数据库的隔离级别
    {
       Read Uncommited:读取未提交的数据(会出现脏读 不可重复读 幻读)
       Read Commited:读已提交的数据(会出现不可重复读和幻读)
       Repeatable Read:可重复读(会出现幻读)
       Serializable:串行化
    }

    脏读:一个事务读取到另外一个事务未提交的更新的数据
    不可重复读:在同一事务中,多次读取同一个数据返回结果有所不同,就是后续的读取可以读到另外一个事务的已经的已经提交的更新数据
    可重复读:在同一个事务多次读取数据时,能够保证所读取的数据一样,也就是后读取的不能读到另外一个事务已经提交的数据
    幻读:一个事务读取到另外一个事务已经提交的更新的数据

    针对查询方法
    @Transactional(propagation=Propagation.NOT_SUPPORTED)针对某个方法不开启事务
    @Transactional(propagation=Propagation.REQUIRED)默认的事务支持

    例子:
    public class Bean1 {
      @Transactional(propagation=Propagation.Required)
      public void update() {
         executeUpdate(SQL);
      }
    }
    public class Bean2 {
      @Transactional(propagation=Propagation.SUPPORTS)
      public void update() {
         executeUpdate(SQL);
      }
    }

    public class Transaction {
      @Transactional(propagation=Propagation.REQUIRES_NEW)
      public void test1()
      {
         bean1.update();
         bean2.update();
      }
       @Transactional(propagation=Propagation.NOT_SUPPORTED)
      public void test2()
      {
         bean1.update();
         bean2.update();
       }
       @Transactional(propagation=Propagation.SUPPORTS)
       public void test3()
       {
          bean1.update();
          bean2.update();
        }
    }
    @Transactional(noRollbackFor=RuntimeException.class)方法事务说明
    @Transactional(RollbackFor=Exception.class)
    @Transactional(readOnly=true)
    @Transactional(timeout=100)
    @Transactional(isolation)数据库的隔离级别
    {
       Read Uncommited:读取未提交的数据(会出现脏读 不可重复读 幻读)
       Read Commited:读已提交的数据(会出现不可重复读和幻读)
       Repeatable Read:可重复读(会出现幻读)
       Serializable:串行化
    }

    脏读:一个事务读取到另外一个事务未提交的更新的数据
    不可重复读:在同一事务中,多次读取同一个数据返回结果有所不同,就是后续的读取可以读到另外一个事务的已经的已经提交的更新数据
    可重复读:在同一个事务多次读取数据时,能够保证所读取的数据一样,也就是后读取的不能读到另外一个事务已经提交的数据
    幻读:一个事务读取到另外一个事务已经提交的更新的数据

    针对查询方法
    @Transactional(propagation=Propagation.NOT_SUPPORTED)针对某个方法不开启事务
    @Transactional(propagation=Propagation.REQUIRED)默认的事务支持

    例子:
    public class Bean1 {
      @Transactional(propagation=Propagation.Required)
      public void update() {
         executeUpdate(SQL);
      }
    }
    public class Bean2 {
      @Transactional(propagation=Propagation.SUPPORTS)
      public void update() {
         executeUpdate(SQL);
      }
    }

    public class Transaction {
      @Transactional(propagation=Propagation.REQUIRES_NEW)
      public void test1()
      {
         bean1.update();
         bean2.update();
      }
       @Transactional(propagation=Propagation.NOT_SUPPORTED)
      public void test2()
      {
         bean1.update();
         bean2.update();
       }
       @Transactional(propagation=Propagation.SUPPORTS)
       public void test3()
       {
          bean1.update();
          bean2.update();
        }
    }

    //事务传播属性
    @Transactional(propagation=Propagation.REQUIRED)//如果有事务,那么加入事务,没有的话新创建一个
    @Transactional(propagation=Propagation.NOT_SUPPORTED)//这个方法不开启事务
    @Transactional(propagation=Propagation.REQUIREDS_NEW)//不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
    @Transactional(propagation=Propagation.MANDATORY)//必须在一个已有的事务中执行,否则抛出异常
    @Transactional(propagation=Propagation.NEVER)//不能在一个事务中执行,就是当前必须没有事务,否则抛出异常
    @Transactional(propagation=Propagation.SUPPORTS)//其他bean调用这个方法,如果在其他bean中声明了事务,就是用事务。没有声明,就不用事务。
    @Transactional(propagation=Propagation.NESTED)//如果一个活动的事务存在,则运行在一个嵌套的事务中,如果没有活动的事务,则按照REQUIRED属性执行,它使用一个单独的事务。这个书屋拥有多个回滚的保存点,内部事务的回滚不会对外部事务造成影响,它只对DataSource TransactionManager事务管理器起效。
    @Transactional(propagation=Propagation.REQUIRED,readOnly=true)//只读,不能更新,删除
    @Transactional(propagation=Propagation.REQUIRED,timeout=30)//超时30秒
    @Transactional(propagation=Propagation.REQUIRED,isolation=Isolation.DEFAULT)//数据库隔离级别



    参考资料有:
    http://www.cnblogs.com/xupei/archive/2011/01/07/1929632.html
    http://hi.baidu.com/qmzwhl/blog/item/aae2d6581afd17d29d8204ca.html

  • 相关阅读:
    Ubuntu实现树莓派交叉编译
    IOS页面自动布局 之 NSLayoutConstraint基础篇
    环信SDK与Apple Watch的结合(3)
    数据结构C语言版干货------->线性表之顺序表
    Java的反射机制(应用篇)
    Java之泛型深解
    Java集合类--->入门下篇
    Java之泛型浅解
    Java集合类--->入门上篇
    数据结构基础铺垫篇000
  • 原文地址:https://www.cnblogs.com/yujy/p/2795231.html
Copyright © 2011-2022 走看看