Hibernate Envers - 自定义RevisionEntity - 如何获取记录

时间:2016-10-19 11:39:06

标签: hibernate-envers

我编写了自定义的RevisionEntity类来存储其他数据(例如用户名),如下所示:

@Entity
@RevisionEntity(AuditListener.class)
@Table(name = "REVINFO", schema = "history")
@AttributeOverrides({ 
        @AttributeOverride(name = "timestamp", column = @Column(name = "REVTSTMP")),
        @AttributeOverride(name = "id", column = @Column(name = "REV")) })
public class AuditEntity extends DefaultRevisionEntity {

    private static final long serialVersionUID = -6578236495291540666L;

    @Column(name = "USER_ID", nullable = false)
    private Long userId;

    @Column(name = "USER_NAME")
    private String username;

    public Long getUserId() {
        return userId;
    }

    public void setUserId(Long userId) {
        this.userId = userId;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }
}

我可以看到数据库中的所有行都已正确存储,REVINFO表也包含用户名。

我想查询数据库以从我的自定义RevisionEntity获取详细信息,例如用户名。 我该怎么做?是否有任何支持的API来获取它?

1 个答案:

答案 0 :(得分:2)

让我们假设您知道您对修订实体元数据感兴趣的实体的标识符,您可以使用以下方法轻松查询该信息:

final AuditReader auditReader = AuditReaderFactory.get( session );
List<?> results = auditReader.createQuery()
     .forRevisionsOfEntity( YourEntityClass.class, false, false )
     .add( AuditEntity.id().eq( yourEntityClassId ) )
     .getResultList();

返回的结果将包含一个Object数组,例如Object[]其中results[1]将包含修订实体实例,其中包含您想要的相关信息。

有关更多详细信息,请参阅java文档注释here

如果您只有修订号,则可以直接访问修订实体实例:

// I use YourAuditEntity here because AuditEntity is actually an Envers class
YourAuditEntity auditEntity = auditReader
   .findRevision( YourAuditEntity.class, revisionId );

有关AuditReader界面的更多详细信息,您可以查看java文档here