深入理解JPA中的事务与并发控制
1. 事务基础概述
在应用程序开发中,常常需要一次性执行多个操作。例如,在拍卖结束时,应用程序需要完成以下三项任务:
1. 找出拍卖物品的最高出价(即获胜出价)。
2. 向物品卖家收取拍卖费用。
3. 通知卖家和成功出价者。
如果由于外部信用卡系统故障而无法收取拍卖费用,业务需求可能要求上述所有操作要么全部成功,要么全部失败。这种一组操作就被称为一个事务或工作单元。如果其中任何一个步骤失败,整个工作单元都必须失败。
2. ACID属性
ACID代表原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。
- 原子性 :事务中的所有操作都作为一个原子单元执行。
- 一致性 :事务允许多个用户同时处理相同的数据,而不会破坏数据的一致性(符合数据库完整性规则)。
- 隔离性 :一个事务不应该对其他并发运行的事务可见,它们应该独立运行。
- 持久性 :事务中所做的更改应该是持久的,即使在事务成功完成后系统出现故障。
此外,还需要保证事务的正确性。例如,业务规则规定应用程序只向卖家收取一次费用,而不是两次。这是一个合理的假设,但可能无法通过数据库约束来表达。因此,事务的正确性由应用程序负责,而一致性由数据库负责。这些事务属性共同定义了ACID标准。
JPA 2中还有一些新特性:
- 引入了新的锁模