事务管理的核心接口
在Spring的所有JAR包中,包含一个名为spring-tx-5.2.3.RELEASE
的JAR包,该包就是Spring提供的用于事务管理的依赖包。在该JAR包的org.springframework.transaction
包中,有3个接口文件PlatformTransactionManager
、TransactionDefinition
和TransactionStatus
,如下图所示:
PlatformTransactionManager
接口是Spring提供的平台事务管理器,主要用于管理事务。该接口中提供了三个事务操作的方法,具体如下:
TransactionStatus getTransaction(TransactionDefinition definition);
用于获取事务状态信息void commit(TransactionStatus status);
用于提交事务void rollback(TransactionStatus status);
用于回滚事务
PlatformTransactionManager
接口只是代表事务管理的接口,并不知道底层是如何管理事务的,具体如何管理事务则由它的实现类来完成。该接口常见的几个实现类如下:
org.springframework.jdbc.datasource.DataSourceTransactionManager
用于配置JDBC数据源的事务管理器org.springframework.orm.hibernate4.HibernateTransactionManager
用于配置Hibernate的事务管理器org.springframework.transaction.jta.JtaTransactionManager
用于配置全局事务管理器
TransactionDefinition
接口是事务定义(描述)的对象,该对象中定义了事务规则,并提供了获取事务相关信息的方法,具体如下表所示:
方法 | 说明 |
---|---|
String getName( ); | 获取事务对象名称 |
int getIsolationLevel( ); | 获取事务的隔离级别 |
int getPropagationBehavior( ); | 获取事务的传播行为 |
int getTimeout( ); | 获取事务的超时时间 |
boolean isReadOnly( ); | 获取事务是否只读 |
上述方法中,事务的传播行为是指在同一个方法中,不同操作前后所使用的事务传播行为有很多种,具体如图所示:
在事务管理过程中,传播行为可以控制是否需要创建事务以及如何创建事务,通常情况下,数据的查询不会影响原数据的改变,所以不需要进行事务管理,而对于数据的插入、更新和删除操作,必须进行事务管理。如果没有指定事务的传播行为,Spring默认传播行为是REQUIRED
。
事务管理的方式
主要分为俩种方式:编程式事务管理和声明式事务管理,具体如下如所示:
声明式事务管理最大的优点在于开发者无需通过编程的方式来管理事务,只需在配置文件中进行相关的事务规则声明,就可以将事务应用到业务逻辑中。这使得开发人员可以更加专注于核心业务逻辑代码的编写,在一定程度上减少了工作量,提高了开发效率,所以在实际开发中,通常都推荐使用声明式事务管理。