Ebean 和 Play Framework 2 中的 OptimisticLockException

2024-03-03

我将 Ebean 与 Play Framework 2 一起使用,有时它会出现此类 OptimisticLockException:

play.core.ActionInvoker$$anonfun$receive$1$$anon$1: Execution exception [[OptimisticLockException: Data has changed. updated [0] rows sql[update manager set modification_time=?, session_id=?, expiration_date=? where id=? and rating=? and creation_time=? and modification_time=? and name=? and surname=? and login=? and password_hash=? and email=? and session_id=? and expiration_date=?] bind[null]]]

当很少有参与者开始访问数据库时就会发生这种情况。

所以,Manager 类是:

public class Manager extends Model {
@Getter @Setter
Long id;

@Getter @Setter
private String name;

@Getter @Setter
private String surname;

@Column(unique = true)
@Getter @Setter
private String login;

@Getter @Setter
private String passwordHash;

@Getter @Setter
private String email;

@Embedded
@Getter @Setter
private ManagerSession session;

@Getter
private Timestamp creationTime;

@Getter
private Timestamp modificationTime;

@Override
public void save() {
    this.creationTime       = new Timestamp(System.currentTimeMillis());
    this.modificationTime   = new Timestamp(System.currentTimeMillis());
    super.save();
}

@Override
public void update() {
    this.modificationTime   = new Timestamp(System.currentTimeMillis());
    super.update();
}

}

save() 和 update() 钩子使用了 @PrePersist 注释,因为 Ebean 不支持它。 据我所知@Version注释总是带来乐观锁模式,所以我开始使用这样的技巧。我知道什么是乐观锁,但是当许多参与者应该修改相同的数据库记录时,这种情况应该如何解决,最后一次修改会获胜吗?


解决方案: https://play.lighthouseapp.com/projects/82401/tickets/207-ebean-saving-detached-entity-directly-from-form-causes-problems

问题:直接从 Play Form 保存分离的 EBean 模型会导致 OptimisticLockException,或者在使用 @Version 时会导致 NullpointerException。

Form<Venue> form = form(Venue.class).bindFromRequest();
form.get().update(id); // this causes the exception

解决方案:在从请求参数绑定之前,表单应该支持从数据库为其提供一个对象。然后,在请求中找到的参数应该覆盖对象上的相关属性。也许在bindFromRequest()之前调用fill():

Form<Venue> form = form(Venue.class).fill(Venue.find.byId(id)).bindFromRequest();
form.get().update(id);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Ebean 和 Play Framework 2 中的 OptimisticLockException 的相关文章

随机推荐