JPA 2.0开始同时提供了乐观锁(optimistic locking)和悲观锁(pessimistic locking)。
乐观锁(optimistic locking)
在数据的改变被提交之前,persistence provider检查自从上次读取数据后数据是否被其他事务修改,删除。
实体有一个版本属性,与之对应的数据库表中也有一列字段用来表示版本,每次数据被变更,版本号将会被增加,事务在提交时,将会检查当前版本属性,对比判断数据是否在上一次读取后被其他事物修改过,如果修改过,“javax.persistence.OptimisticLockException”将会被抛出,同时事务被回滚。
这种加锁方式的并发冲突在事物提交时才被检查。
如果数据不太可能被频繁的并发访问与修改,乐观锁是一个比较好的方式。
悲观锁(pessimistic locking)
这种加锁方式,会在事务期间,长期持有锁,直到事务完成。这可以在锁被释放前,阻止其他事物修改,删除同一份数据。这种加锁方式一般是基于数据库行锁实现的。
这种加锁方式的并发冲突在事物提交前就得到检查。
如果数据将会被很频繁的并发访问与修改,悲观锁是一种比较好的方式。