gpt4 book ai didi

java - hibernate 环境 : get only changed fields

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:35:31 24 4
gpt4 key购买 nike

我怎样才能只从被审计的实体中获取修改过的字段?

当我使用

AuditQuery query = getAuditReader().createQuery().forEntitiesAtRevision(MyEntity.class, revisionNumber).getResultList()

我得到所有字段;但我只想修改字段?

最佳答案

没有修改标志特征

如果您没有在 @Audited 注释上使用 Modified Flags 功能,获得已审核属性从修订版 X 更改为修订版 Y 的唯一方法是实际上获取两个修订,然后自己比较两个对象实例之间的实际字段值。

具有修改标志功能

假设您在 @Audited 注释上使用 Modified Flags 功能,目前唯一的方法是获取给定实体实例的修订号并使用这些修订和审计列的先验知识,使用 Envers 查询 API 询问该修订版是否更改了属性。

显然,这种方法并不理想,因为它确实对用户代码部分强加了一些先验知识,以了解要审核的字段以获得所需的结果。

List<Number> revisions = reader.getRevisions( MyEntity.class, myEntityId );
for ( Number revisionNumber : revisions ) {
for ( String propertyName : propertyNamesToCheckList ) {
final Long hits = reader.createQuery()
.forRevisionsOfEntity( MyEntity.class, false, false )
.add( AuditEntity.id().eq( myEntityId ) )
.add( AuditEntity.revisionNumber().eq( revisionNumber ) )
.add( AuditEntity.propertyName( propertyName ).hasChanged() )
.addProjection( AuditEntity.id().count() )
.getSingleResult();

if ( hits == 1 ) {
// propertyName changed at revisionNumber
}
else {
// propertyName didn't change at revisionNumber
}
}
}

修改标志属性更改查询

在 Hibernate Envers 6.0 中,我们引入了一个新的查询,它将 forRevisionsOfEntity 与修改后的标志查询机制相结合,不仅可以获取给定实体类类型和主键的修改实例,还可以获取每次修订时修改的字段列表。

以下伪代码给出了 future API 的示例:

List results = reader.forRevisionsOfEntityWithChanges( MyEntity.class false )
.add( AuditEntity.id().eq( entityId ) )
.getResultList();

Object previousEntity = null;
for ( Object row : results ) {
Object[] rowArray = (Object[]) row;
final MyEntity entity = rowArray[0];
final RevisionType revisionType = (RevisionType) rowArray[2];
final Set<String> propertiesChanged = (Set<String>) rowArray[3];
for ( String propertyName : propertiesChanged ) {
// using the property name here you know
// 1. that the property changed in this revision (no compare needed)
// 2. Can get old/new values easily from previousEntity and entity
}
}

此功能可能会被扩展或更改,因为它将被视为实验性,但这是用户要求的东西,我们至少打算提供基于此功能的第一遍在修改后的标志上。

目前我们还没有决定我们是否或如何为未修改的标志支持这一点,所以目前唯一的选择将是暴力 bean 比较。

有关此功能的更多详细信息,请参阅 HHH-8058 .

关于java - hibernate 环境 : get only changed fields,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43472893/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com