【快学springboot】8.JPA乐观锁OptimisticLocking

栏目: Java · 发布时间: 5年前

内容简介:当涉及到企业应用程序时,正确地管理对数据库的并发访问是至关重要的。为此,我们可以使用Java Persistence API提供的乐观锁定机制。它导致在同一时间对同一数据进行多次更新不会相互干扰。为了使用OptimisticLocking,我们需要一个实体(Entity),其中包含一个带有@Version注释的属性。在使用它时,每个读取数据的事务都持有version属性的值。在事务想要进行更新之前,它将再次检查version属性。如果值在此期间发生了更改,则抛出ObjectOptimisticLocking

当涉及到企业应用程序时,正确地管理对数据库的并发访问是至关重要的。为此,我们可以使用Java Persistence API提供的乐观锁定机制。它导致在同一时间对同一数据进行多次更新不会相互干扰。为了使用OptimisticLocking,我们需要一个实体(Entity),其中包含一个带有@Version注释的属性。在使用它时,每个读取数据的事务都持有version属性的值。在事务想要进行更新之前,它将再次检查version属性。如果值在此期间发生了更改,则抛出ObjectOptimisticLockingFailureException。否则,事务提交update并递增version的值。这种机制适用于读操作比更新或删除操作多得多的应用程序。

新建一个UserEntity.java

@Entity
@Table(name = "user")
@Data
@OptimisticLocking
public class User {

 @Id
 @GeneratedValue(strategy = GenerationType.SEQUENCE)
 private Integer id;

 @Column(name = "username", unique = true, nullable = true, length = 50)
 private String username;

 private String password;

 @Version
 private Integer version;

 @PrePersist
 public void prePersist() {
 version = 0;
 }

}
复制代码

spring data jpa在上一篇文章已经做过一些讲解了 【快学springboot】7.使用Spring Boot Jpa 。感兴趣的朋友可以看看。这里定义了一个version字段,使用了Version注解标识。PrePersist这个注解表示在新增数据之前执行。

新建UserRepo接口

public interface UserRepo extends PagingAndSortingRepository<User, Integer>, JpaSpecificationExecutor<User> {
 
}
复制代码

新建一个UserTest类,继承SpringbootApplicationTests

public class UserTest extends SpringbootApplicationTests {
 
}
复制代码

SpringbootApplicationTests这个类是使用Spring initialize新建项目的时候自动生成的用来做单元测试的类。在UserTest上注入UserRepo,并且写一个新增user的单测。

【快学springboot】8.JPA乐观锁OptimisticLocking

执行之后查看数据库。

【快学springboot】8.JPA乐观锁OptimisticLocking

该记录已经被创建出来了。

测试update该记录

【快学springboot】8.JPA乐观锁OptimisticLocking

执行后查看数据库:

【快学springboot】8.JPA乐观锁OptimisticLocking

可以看到version字段自增了1。

测试JPA乐观锁

新建一个方法,如下

【快学springboot】8.JPA乐观锁OptimisticLocking

这里查询了两次id为1的记录,然后分别更新了这条记录。根据前面的描述,这里会抛出一个ObjectOptimisticLockingFailureException异常。启动测试,结果如下:

【快学springboot】8.JPA乐观锁OptimisticLocking

这是符合预期的。看下数据库的version,在这种情况下,我们的预期结果是version变为2。

【快学springboot】8.JPA乐观锁OptimisticLocking

通过数据库的值查看,测试都是符合预期的。

去掉User的OptimisticLocking注解

我们把User实体的OptimisticLocking注解去掉,然后再次执行上面的方法。

【快学springboot】8.JPA乐观锁OptimisticLocking

这一次程序顺利执行了,然后查看下数据库的记录:

预期应该是version会变为3,然后username变为happyjava-new2。

【快学springboot】8.JPA乐观锁OptimisticLocking

通过结果来看,这是符合预期的。

总结

spring data jpa通过OptimisticLocking实现了乐观锁,该乐观锁不是通过数据库自身去实现的,它是通过version字段(需要Version注解标识)去实现的。如果update的数据时候,发现数据库的version大于等于当前的version,则会抛出ObjectOptimisticLockingFailureException,错误信息是

Row was updated or deleted by another transaction 
复制代码

以上所述就是小编给大家介绍的《【快学springboot】8.JPA乐观锁OptimisticLocking》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

B2B品牌管理

B2B品牌管理

(美)菲利普·科特勒、(德)弗沃德 / 楼尊 / 2008-1 / 35.00元

《B2B品牌管理》是第一本专门系统地阐述B2B品牌化的专业书籍,由营销大师菲利普•科特勒与弗沃德教授合作而成。他们以非凡的智慧和深厚的经验告诫B2B企业如何运用目标明确、重点突出的品牌化战略取得市场竞争优势地位,从而更加接近顾客,也更接近成功。在众多关于品牌的书籍中,《B2B品牌管理》的独特价值在于其根据实际环境探讨B2B品牌和品牌化问题,重点介绍和分析前沿的思想和最佳实践;通过与B2C企业的品牌......一起来看看 《B2B品牌管理》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码