如何解决Spring Data Envers - 使用不再存在的枚举值获取实体修订失败
我有一个包含枚举字段和与其他表的关系的实体。问题是枚举随着时间的推移发生了变化,我需要查看现在无效的更改值。
@Audited
@Entity
@Table(name = "FILE")
public class FileEntity extends RevisionAudit {
@ElementCollection(fetch = FetchType.EAGER)
@CollectionTable(
name = "FILE_TYPE",joinColumns = @JoinColumn(name = "FILE_ID")
)
private Set<FileTypeEntity> types = new HashSet<>();
@Enumerated(EnumType.STRING)
private FileFormat format;
}
使用常规 AuditReader.forRevisionsOfEntity 获取实体自然会失败,因为它尝试填充枚举字段。我试图将字段值映射到这样的字符串:
auditQuery.addProjection(property("format").function("to_char"))
这也适用于无效的枚举值。但是添加场投影仅返回投影场,我无法向 types
关系添加投影。
是否有其他方法可以将值强制为字符串或将关系添加到投影中?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。