Spring之使用事务缘由(1-原始实现)

事务简介

事务管理是企业级应用程序开发中必不可少的技术,用来确保数据的完整性和一致性。事务就是一系列的动作,它们被当做一个单独的工作单元。这些动作要么全部完成,要么全部不起作用。

事务的四个关键属性(ACID)

原子性(atomicity):事务是一个原子操作,由一系列动作组成。事务的原子性确保动作要么全部完成要么完全不起作用。

一致性(consistency): 一旦所有事务动作完成,事务就被提交。数据和资源就处于一种满足业务规则的一致性状态中。

隔离性(isolation):可能有许多事务会同时处理相同的数据,因此每个事物都应该与其他事务隔离开来,防止数据损坏。

持久性(durability):一旦事务完成,无论发生什么系统错误,它的结果都不应该受到影响。通常情况下,事务的结果被写到持久化存储器中。

为什么要使用Spring的事务管理呢?要回答这个问题,我们需要先看下原始实现事务管理的代码片段:

Spring之使用事务缘由(1-原始实现)
 

这种实现至少存在如下两个问题:1. 必须为不同的方法重写类似的样板代码;2. 这段代码是特定于 JDBC 的,一旦选择类其它数据库存取技术,代码需要作出相应的修改。而Spring 从不同的事务管理 API 中抽象了一整套的事务机制。开发人员不必了解底层的事务 API,就可以利用这些事务机制。有了这些事务机制,事务管理代码就能独立于特定的事务技术了。Spring 的核心事务管理抽象是org.springframework.transaction.PlatformTransactionManager,它为事务管理封装了一组独立于技术的方法。无论使用 Spring 的哪种事务管理策略(编程式或声明式),事务管理器都是必须的。

Spring提供了org.springframework.jdbc.datasource.DataSourceTransactionManager,org.springframework.transaction.jta.JtaTransactionManager和org.springframework.transaction.jta.HibernateTransactionManager等事务管理器,事务管理器以普通的 Bean 形式声明在 Spring IOC 容器中。

作为企业级应用程序框架,Spring 在不同的事务管理 API 之上定义了一个抽象层。而应用程序开发人员不必了解底层的事务管理 API,就可以使用 Spring 的事务管理机制。Spring 既支持编程式事务管理,也支持声明式的事务管理。

编程式事务管理:将事务管理代码嵌入到业务方法中来控制事务的提交和回滚。在编程式管理事务时,必须在每个事务操作中包含额外的事务管理代码。

声明式事务管理:大多数情况下比编程式事务管理更好用。它将事务管理代码从业务方法中分离出来,以声明的方式来实现事务管理。事务管理作为一种横切关注点,可以通过 AOP 方法模块化。 Spring 通过 Spring AOP 框架支持声明式事务管理。

相关推荐