码迷,mamicode.com
首页 > 编程语言 > 详细

spring的事务传播与隔离级别等相关配置

时间:2018-09-12 22:05:50      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:丢失   bsp   insert   persist   支持   comm   man   eth   运行   


<!-- 配置通知 -->

//   脏读  :一个事务读到了另一个事务的未提交的数据

//  不可重复读 :一个事务读到了另一个事务已经提交的 update 的数据导致多次查询结果不一致.

//  虚幻读  :一个事务读到了另一个事务已经提交的 insert 的数据导致多次查询结果不一致. 

事务的传播行为:

* 保证同一个事务中

  PROPAGATION_REQUIRED 支持当前事务,如果不存在 就新建一个(默认)

  PROPAGATION_SUPPORTS 支持当前事务,如果不存在,就不使用事务

  PROPAGATION_MANDATORY 支持当前事务,如果不存在,抛出异常
* 保证没有在同一个事务中

  PROPAGATION_REQUIRES_NEW 如果有事务存在,挂起当前事务,创建一个新的事务

  PROPAGATION_NOT_SUPPORTED 以非事务方式运行,如果有事务存在,挂起当前事务

  PROPAGATION_NEVER 以非事务方式运行,如果有事务存在,抛出异常

  PROPAGATION_NESTED 如果当前事务存在,则嵌套事务执行

隔离级别

   DEFAULT为数据库默认隔离级别

  • Read Uncommited :读未提交数据( 会出现脏读,不可重复读,幻读 ,避免了 第一类丢失 更新 )
  • Read Commited :读已提交的数据(会出现不可重复读,幻读)
  • Repeatable Read :可重复读(会出现幻读)
  • Serializable :串行化

//   *为通配符,即代表以save为开头的所有方法,即表示符合此命名规则的方法作为一个事务

     read-only  只读

<tx:advice id="txAdvice" transaction-manager="transactionManager" >
<tx:attributes>
<tx:method name="save*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
<tx:method name="persist*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
<tx:method name="update*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
<tx:method name="modify*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
<tx:method name="delete*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
<tx:method name="remove*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
<tx:method name="get*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="true" />
<tx:method name="find*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="true" />
<tx:method name="*" isolation="REPEATABLE_READ" propagation="REQUIRED" read-only="false" />
</tx:attributes>
</tx:advice>

spring的事务传播与隔离级别等相关配置

标签:丢失   bsp   insert   persist   支持   comm   man   eth   运行   

原文地址:https://www.cnblogs.com/crazycatlong/p/9637593.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!