Spring基于注解配置事务的属性
作者:halftwo
本文实例为大家分享了Spring基于注解配置事务的属性,供大家参考,具体内容如下
一、事务属性概述
在Spring中,事务属性描述了事务策略如何应用到方法上,事务属性包含5个方面:
① 传播行为
② 隔离级别
③ 回滚策略
④ 超时时间
⑤ 是否只读
二、事务的传播行为属性##
1、当事务方法被另一个事务方法调用时,必须指定事务应该如何传播。例如,方法可能继续在现有的事务中允许,也可能开启一个新事务,并在自己的事务中运行。
2、事务的传播行为可以由传播属性指定,Spring定义了7种类型的传播行为。其中最常用的是REQUIRED
和REQUIRES_NEW
。
3、事务的传播属性可以在@Transactional注解的propagation属性中定义。
4、举个例子:
/** * 使用 @Transactional 指定事务方法 */ @Service("bookShopService") public class BookShopServiceImpl implements BookShopService { /** * 1. 添加事务注解@Transactional。 * 2. 使用 propagation 指定事务的传播行为, * 即当前事务方法被另外一个事务方法调用时,如何使用事务: * 是使用调用方法的事务,还是开启一个新事务(使用自己的事务)。 * 3. propagation: * ① 默认值是 Propagation.REQUIRED, 即使用调用方法的事务。 * ② 可以指定为 Propagation.REQUIRES_NEW, 即在调用方法的事务中开启一个新事务(自己的事务)。 */ @Transactional(propagation = Propagation.REQUIRES_NEW) public void purchaseSigleBook(String acctName, String bookId) { ... } }
三、事务的隔离级别##
1、从理论上来说,事务应该彼此完全隔离,以避免并发事务所导致的问题。然而,那样会对性能产生极大的影响,因为事务必须按顺序运行。
2、在实际开发中,为了提升性能,事务会以较低的隔离级别运行。
3、事务的隔离级别可以通过隔离级别事务属性(isolation
)指定。
4、Spring支持的事务隔离级别:
事务的隔离级别要得到底层数据库引擎的支持,而不是应用程序或者框架的支持。
Oracle 支持的2种事务隔离级别:READ_COMMIT。
MySQL 支持4种事务隔离级别:READ-UNCOMMITTED、READ-COMMITTED、REPEATABLE-READ 和 SERIALIZABLE。
5、用@Transactional
注解声明式的管理事务时可以在 @Transactional 的isolation
属性中设置隔离级别。
6、举个例子:
/** 1. 使用 @Transactional 指定事务方法 */ @Service("bookShopService") public class BookShopServiceImpl implements BookShopService { /** * 1. 添加事务注解@Transactional。 * 2. 使用isolation属性指定事务的隔离级别,最常用的的取值是: Isolation.READ_COMMITTED。 */ @Transactional(isolation = Isolation.READ_COMMITTED) public void purchaseSigleBook(String acctName, String bookId) { ... } }
四、事务的回滚属性##
1、默认情况下只有未检查异常( RuntimeException 和 Error 类型的异常)会导致事务回滚,而检查异常不会。
2、事务回滚的规则可以通过 @Transactional
注解的 rollbackFor
和 noRollbackFor
属性来定义,这两个属性被声明为Class[] 类型的,因此可以为这两个属性指定多个异常类。
① rollbackFor:指定遇到哪些异常时必须进行回滚。
② noRollbackFor:指定遇到哪些异常时,必须不回滚。
3、举个例子:
/** * 使用 @Transactional 指定事务方法 */ @Service("bookShopService") public class BookShopServiceImpl implements BookShopService { /** * 1. 添加事务注解@Transactional。 * 2. 使用rollbackFor 和 noRollbackFor指定事务遇到哪些异常时进行强制回滚或者强制不回滚。 * 默认情况下,Spring声明事务对所有运行时异常进行回滚.通常取默认值。 */ @Transactional(noRollbackFor = {UserAccounException.class}) public void purchaseSigleBook(String acctName, String bookId) { ... } }
五、事务的只读属性##
1、如果一个事务只读取数据但不修改数据,数据库引擎可以对这个事务进行优化。
2、只读事务属性:表示这个事务只读取数据但不更新数,这样可以帮助数据库进行优化事务。
3、只读属性可以在@Transactional
注解中readOnly
属性中定义,其取值只有true和false。
4、举个例子:
/** * 使用 @Transactional 指定事务方法 */ @Service("bookShopService") public class BookShopServiceImpl implements BookShopService { /** * 1. 添加事务注解@Transactional。 * 2. 使用 readOnly 只读事务的只读属性,表示这个事务是否只读取数据而不修改数据。 */ @Transactional(readOnly = true) public void purchaseSigleBook(String acctName, String bookId) { ... } }
##六、事务的超时属性##
1、由于事务可以在行和表上获得锁,因此长期运行的事务会占用资源,并对整体性能产生影响。
2、超时事务属性:事务在强制回滚之前可以保持多久,这样可以防止长期运行的事务占用资源。
3、超时属性可以在 @Transactional注解中timeout属性中定义,其单位为秒。
4、举个例子:
/** * 使用 @Transactional 指定事务方法 */ @Service("bookShopService") public class BookShopServiceImpl implements BookShopService { /** * 1. 添加事务注解@Transactional。 * 2. 使用 timeout 指定事务的超时属性,表示在强制回滚之前,这个事务能运行多久,单位是秒。 */ @Transactional(timeout = 3) public void purchaseSigleBook(String acctName, String bookId) { ... } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。