4

是否可以在每次刷新到数据库之前更新某些列?我有modifiedOnmodifiedBy列,并希望在每次数据库更新时更新它们,类似于数据库触发器。JPA可以吗?

4

2 回答 2

1

免责声明:以下仅适用于 Hibernate / JPA。

您可以modifiedOn使用 JPA 像这样更新属性:

public class Entity {

     private Date modifiedOn;

     @PreUpdate 
     @PrePersist
     public void updateModified() {
         modifiedOn = new Date();
     }
}

至于modifiedBy,它有点棘手,因为 JPA 规范不鼓励在生命周期回调方法中引用其他实体。此外,您需要了解当前用户,这可能属于服务层。

您可以使用EntityListener这样的(但是,这仍然使用回调方法)

@Entity
@EntityListeners({MyListener.class})
public class MyEntity {
    Date modifiedOn;
    User modifiedBy;
    ...
}

EntityListener 中的一个:

public class MyListener {

    CurrentUserProvider provider; // Implement this and make sure it is set

    @PreUpdate
    @PrePersist
    public void updateModifier(MyEntity entity) {
         entity.setModifiedOn(new Date());
         entity.setModifiedBy(provider.getCurrentUser());
    }
}
于 2012-12-12T08:16:42.210 回答
-1

显然,JPA 在规范中定义了实体回调,例如@PrePersist、@PreUpdate。规范的简单修订会给你更多的细节

于 2012-12-12T08:12:37.150 回答