• 注册
当前位置:1313e > 默认分类 >正文

事务隔离级别和传播行为以及@Transactional使用规范

一、事务隔离级别:

数据库事务的隔离级别有4个,由低到高依次为Read uncommitted、Read committed、Repeatable read、Serializable,这四个级别可以逐个解决脏读、不可重复读、幻读这几类问题。

1. ISOLATION_READ_UNCOMMITTED:这是事务最低的隔离级别,它充许令外一个事务可以看到这个事务未提交的数据。

      这种隔离级别会产生脏读,不可重复读和幻像读。

2. ISOLATION_READ_COMMITTED:保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据

3. ISOLATION_REPEATABLE_READ:这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。

      它除了保证一个事务不能读取另一个事务未提交的数据外,还保证了避免下面的情况产生(不可重复读)。

4. ISOLATION_SERIALIZABLE:这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。
      除了防止脏读,不可重复读外,还避免了幻像读

 5.   DEFAULT :这是一个PlatfromTransactionManager默认的隔离级别,这个默认隔离级别是与具体的数据库相关的

     采取的是具体数据库的默认隔离级别 

      Mysql 默认:可重复读  Oracle 默认:读已提交

二、事务传播行为:

1.PROPAGATION_REQUIRED – 支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。

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

3.PROPAGATION_MANDATORY – 支持当前事务,如果当前没有事务,就抛出异常。

4.PROPAGATION_REQUIRES_NEW – 新建事务,如果当前存在事务,把当前事务挂起。

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

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

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

备注:常用的两个事务传播属性是1和4,即PROPAGATION_REQUIRED,PROPAGATION_REQUIRES_NEW
三、项目中使用@Transactional管理事务注意事项

1. 有事物方法调用其他无事物方法时,调用的方法也在事物范围内。如被调用方法也有@Transactional,则看该注解具体配置的事物传播级别,默认为propagation=Propagation.NOT_SUPPORTED,包含事物。2.使用了@Transactional的方法A,对不同类里面使用了@Transactional的方法B调用,B代码不回滚A进行回滚
比如有一个类Test,它的一个方法A,A调用其它类的方法B(B的@Transactional 的 propagation 属性为 Propagation.REQUIRES_NEW),假设B方法执行完成无异常 接下来继续执行a方法报了异常,那么只会回滚a方法 B中的代码则不会回滚

3. 无事物方法调用本类有事物方法时,被调用方法的事物不生效。原因为spring的@Transactional事务生效的一个前提是进行方法调用前经过拦截器TransactionInterceptor,而本类方法的调用为this.方法(),未经过拦截器处理。比如:比如有一个类Test,它的一个方法A,A再调用Test本类的方法B(不管B是否public还是private),但A没有声明注解事务,而B有。则外部调用A之后,B的事务是不会起作用的。(经常在这里出错)     

解决方案(分两步):①(当前类名)AopContext.currentProxy().需调用方法();②在spring配置文件中添加,
"true"/>4. @Transactional 注解只能应用到 public 可见度的方法上5. Spring团队建议在具体的类(或类的方法)上使用 @Transactional 注解,而不要使用在类所要实现的任何接口上。在接口上使用 @Transactional 注解,只能当你设置了基于接口的代理时它才生效。因为注解是 不能继承的。6. @Transactional注解默认只能处理error和RuntimeException及其子类等unchecked异常,要想处理checked异常(编译时异常)则需要配置为rollbackFor=RuntimeException.class

 

转载于:https://www.cnblogs.com/lyx-2018-yh-qingliu/p/10250676.html

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 162202241@qq.com 举报,一经查实,本站将立刻删除。

最新评论

欢迎您发表评论:

请登录之后再进行评论

登录