Spring框架的事务管理

Spring 框架的事务管理是其核心功能之一,主要用于简化数据库事务的控制,确保数据操作的原子性、一致性、隔离性和持久性(ACID 特性)。以下是关于 Spring 事务管理的关键知识点:

1. 事务管理的核心接口

Spring 通过一套抽象接口实现事务管理,核心接口包括:

  • PlatformTransactionManager :事务管理器接口,定义了事务的提交、回滚等操作,具体实现依赖于底层持久化技术(如 JDBC、Hibernate 等)。
    • 常见实现类:
      • DataSourceTransactionManager:用于 JDBC 或 MyBatis。
      • HibernateTransactionManager:用于 Hibernate。
      • JpaTransactionManager:用于 JPA。
  • TransactionDefinition:定义事务属性(如隔离级别、传播行为、超时时间等)。
  • TransactionStatus:表示事务的当前状态(如是否活跃、是否已提交等)。

2. 事务属性

通过TransactionDefinition定义的事务属性包括:

  • 传播行为 :解决多个事务方法调用时的事务传播规则(最常用属性)。
    • REQUIRED(默认):如果当前有事务,则加入;否则新建事务。
    • REQUIRES_NEW:无论当前是否有事务,都新建事务(原事务暂停)。
    • SUPPORTS:如果当前有事务,则加入;否则以非事务方式执行。
    • MANDATORY:必须在事务中执行,否则抛异常。
    • NEVER:必须以非事务方式执行,否则抛异常。
    • NESTED:如果当前有事务,则嵌套在其内部(类似保存点);否则新建事务。
  • 隔离级别 :解决并发事务的干扰问题。
    • DEFAULT(默认):使用数据库默认隔离级别。
    • READ_UNCOMMITTED:允许读取未提交数据(可能脏读、不可重复读、幻读)。
    • READ_COMMITTED:只能读取已提交数据(避免脏读,可能不可重复读、幻读)。
    • REPEATABLE_READ:确保重复读取数据一致(避免脏读、不可重复读,可能幻读)。
    • SERIALIZABLE:完全串行化(避免所有并发问题,性能最低)。
  • 超时时间:事务执行的最大时间(默认由数据库决定)。
  • 只读属性 :设置为true时,事务仅读取数据(优化性能,不允许写操作)。

3. 事务管理方式

Spring 支持两种事务管理方式:

(1)声明式事务管理(推荐)

通过注解或 XML 配置声明事务规则,无需手动编写事务控制代码,耦合度低。

  • 注解方式 (最常用):

    • 在配置类上添加@EnableTransactionManagement开启事务支持。
    • 在需要事务的方法上添加@Transactional注解,并指定属性(如传播行为、隔离级别等)。

    java

    运行

    复制代码
    @Service
    public class UserService {
        @Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.READ_COMMITTED)
        public void transferMoney() {
            // 数据库操作(如转账)
        }
    }
  • XML 配置方式 :通过<tx:advice>和 AOP 切点定义事务规则。

(2)编程式事务管理

手动编写代码控制事务(如TransactionTemplate),灵活性高但耦合度高,适用于复杂场景。

java

运行

复制代码
@Service
public class UserService {
    @Autowired
    private TransactionTemplate transactionTemplate;

    public void transferMoney() {
        transactionTemplate.execute(status -> {
            // 数据库操作
            return null;
        });
    }
}

4. 事务回滚规则

默认情况下,Spring 事务在遇到未检查异常(RuntimeException及其子类)错误(Error 时会回滚,而遇到已检查异常(如IOException 时不会回滚。

可通过@TransactionalrollbackFornoRollbackFor属性自定义回滚规则:

java

运行

复制代码
@Transactional(rollbackFor = Exception.class, noRollbackFor = BusinessException.class)
public void doSomething() throws Exception {
    // ...
}

5. 注意事项

  • @Transactional注解生效范围 :只能标注在public 方法上(非 public 方法注解可能不生效,取决于 AOP 代理方式)。
  • 自调用问题 :同一类中方法调用时,被调用方法的@Transactional注解可能失效(因未经过 Spring 代理),需通过代理对象调用或使用@EnableAspectJAutoProxy(exposeProxy = true)
  • 事务传播行为的合理选择 :例如,日志记录方法通常用REQUIRES_NEW,避免主事务回滚影响日志。
  • 性能考虑 :过高的隔离级别(如SERIALIZABLE)会导致并发性能下降,需根据业务场景选择。

Spring 事务管理通过抽象化底层技术,提供了一致的事务控制方式,极大简化了企业级应用的事务处理逻辑。实际开发中,声明式事务(尤其是注解方式)是主流选择。

相关推荐
b***46247 分钟前
Redis开启远程访问
数据库·redis·缓存
KaiwuDB10 分钟前
KaiwuDB X 向明智控:基于 KaiwuDB 的煤矿综采数据分析系统
数据库
cqsztech10 分钟前
自己如何动手创建oracle 19c 19.3标准版2 DOCKER 镜像
数据库·docker·oracle
2022.11.7始学前端24 分钟前
n8n第四节 表单触发器:让问卷提交自动触发企微消息推送
java·前端·数据库·n8n
十八岁牛爷爷32 分钟前
快速入门从零开始一个qt程序开发,熟悉最主要的开发组件应用
数据库·qt·php
踢球的打工仔33 分钟前
mysql数据备份
数据库·mysql
罗光记35 分钟前
Solon AI 开发学习6- chat- 两种http 流式输入输出
数据库·百度·facebook·新浪微博·segmentfault
韩立学长40 分钟前
【开题答辩实录分享】以《基于Vue Node.js的露营场地管理系统的设计与实现》为例进行选题答辩实录分享
数据库·vue.js·node.js
mqiqe1 小时前
【AI】Weaviate向量数据库详细部署安装应用
数据库·人工智能
DolphinDB智臾科技1 小时前
工业数据流通难题与突破:基于时序数据库的选型思路
数据库·物联网·时序数据库