public class ServiceAImpl implements ServiceA{
@Autowired
private ServiceB serviceB;
@Transactional(propagation=Propagation.REQUIRED)
public void updateParent(Parent parent) {
update(parent);
serviceB.updateChild(parent);
}
}
public class ServiceBImpl implements ServiceB {
@Transactional(propagation=Propagation.REQUIRED_NEW)
public void updateChild(Parent parent) {
checkIfChildHasErrors(parent.getChild()); //throws RuntimeException if Child has errors
update(parent.getChild());
}
}
public class Parent {
@Version
private Integer version;
private Child child;
//insert getters and setters
}
public class Child {
@Version
private Integer version;
//insert getters and setters
}
当外部方法运行时,它调用内部方法。运行内部方法时,外部方法暂停。一旦内部方法完成,它就被提交,因为它是一个不同的事务。外部方法取消暂停。并且它也作为另一个事务提交。
我遇到的问题是,提交外部方法的过程会触发子类的乐观锁定(可能是因为在内部方法结束并提交之后,版本字段的值发生了更改)。由于外部方法的Child实例已经过时,提交它将触发乐观锁定。
我的问题是:有没有一种方法可以防止外部方法触发乐观锁定?
我正在使用Spring 3.0.5和Hibernate 3.6.10
假设您正在使用merge进行更新
对于内部交易
Entity entityUpdated = entityManager.merge(entity);
对于外部交易记录
if (entityUpdated != null){
// if inner transaction rolledback entityUpdated will be null. Condition will save u from nullPointerException
outerEntity.setVersion(entityUpdated.getVersion);
}
entityManager.merge(outerEntity);
我们有一个系统,我们偶尔会得到一个乐观的锁定异常。我们在代码中已经解决了这个问题,但现在我正在查看JPA 2,并看到它有一个用于处理这个问题的注释(@版本) 我们的问题是,一个表上有多个事务,如果表锁已满,则即使未对相同的记录进行更改,也会导致乐观锁定异常。 我们在JBoss 4.2服务器上使用hibernate,数据库可以是MySQL或SQL服务器。 如果改为使用@Version,这会在两个数据
我有一个带有和的微服务。我使用注释对中的表执行操作。我遇到的问题是保存操作花费了太多的时间,所以我希望读取操作不被它阻塞。注意,保存是通过持久化实体来执行的。 当前,在所有并发保存操作完成之前,所有读取操作都不会返回结果,这意味着表被锁定。相反,我希望实现乐观锁定。我怎样才能做到呢?
当我试图理解基于版本的乐观锁定如何防止“最后提交获胜”问题和适当的覆盖时,我遇到了困难。 为了使问题更具体,让我们考虑以下使用 JDBC 的伪代码: 这里,如果其他事务会在更新和提交之间提交其更改呢?如果事务是并发的,那么第一个事务所做的更新尚未提交,因此第二个事务不可见(具有适当的隔离级别),因此第一个事务提交将覆盖第二个交易的更改,而不会出现任何通知或错误。 乐观锁定只是降低了问题发生的概率,
我不确定方法的设计是否恰当。 我们使用乐观锁定,将增量版本放置在每个实体上。这种实体的每次更新都是通过比较和交换算法执行的,该算法的成功与否取决于其他客户端是否同时更新实体。经典的乐观锁定,如hibernate。 我们还需要采取重新尝试的方法。我们使用基于< code>http的存储(etcd ),某些更新请求可能会超时。 这就是问题所在。如何结合乐观锁定和重试?这是我面临的具体问题。 假设我有一
悲观锁:假定会发生并发冲突,屏蔽一切可能违反数据完整性的操作 乐观锁:假设不会发生并发冲突,只在提交操作时检查是否违反数据完整性。 乐观锁与悲观锁的具体区别: http://www.cnblogs.com/Bob-FD/p/3352216.html
> 我在SpringJira上发现了关于使用@Version属性进行乐观锁定的问题。 在实现这一点之前,我如何使用典型的存储库模式来处理这个问题?