0

我有两个经过审计的实体 A 和 B。实体 A 拥有实体 B 的集合(注释为一对多关系)。将 A 的新实例插入数据库时​​,A 和 B 的所有行都处于同一修订版(假设是修订版 1)。然后,对 A 的更新仅影响实体 B 的实例。因此更新后,实体 A 仍处于修订版 1,而 B 的实体处于修订版 2(包括审计表中的 MOD 条目) . 在修订版 3 中,实体 A 被删除。因为实体 B 的集合使用@Cascade 注释,所以属于 A 的实体 B 也被删除。

鉴于这种情况,我如何使用 Envers 创建一个审计查询,该查询获取实体 A 的实例以及修订版 2 的更新实体 B?当我查询实体 A 的所有修订版时,我要么得到 A 的已删除实体,它不包含 B 的实体(修订版 3),要么我得到修订版 1 的 A 也包含修订版 1 的 B 实体。

如果有帮助,请使用 Hibernate 3.6。

4

3 回答 3

3

我通过在相当于您的 A 实体上添加隐藏的 lastUpdated 日期字段解决了类似的问题。

@Entity
public class A {
    private Date lastModified;
    @OneToMany(mappedBy = "a", cascade = CascadeType.ALL )
    private List<B> blist;
    public void touch(){
        lastModified=new Date();
    }
}

然后在相关实体(比如你的 B 字段)中,我添加了以下内容:

public class B {
    @ManyToOne
    private A a; 

    @PreUpdate
    public void ensureParentUpdated(){
        if(a!=null){
            a.touch();
        }
    }
}

这确保了无论何时将修订添加到 B,都会将修订添加到 A,即使它需要许多实体中的自定义代码。

在您的情况下,这将确保 A 的历史记录实际上包含 B 的修订。这样您只需要一个查询即可获取整个 A、Bs 图表的所有修订

于 2012-06-28T12:02:20.980 回答
2

如果您阅读第 2 版的实体 A,您将获得正确的数据。

目前无法获取实体或相关实体更改的修订列表(如您的情况 - rev 2 仅在 B 中进行更改,而不在 a 中更改)。

于 2012-04-12T14:00:19.363 回答
0

在 Hibernate 中,我们可以通过指定惰性来控制子元素的加载。因此,您需要将以下行添加到休眠配置中的类定义中,以便在两种读/写情况下加载所有关联。

<cache usage="read-write"/>

如果您已标记CacheMode.REFRESH,则它将项目写入二级缓存。不要从二级缓存中读取。

如果您在为父母时加载孩子没有问题,您可以转为惰性,这将返回更新的信息。

于 2012-04-12T10:04:55.510 回答