我编写了自定义的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来获取它?
答案 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