我在 Postgresql 上使用 Hibernate 和 Envers 3.6.10。我已经OneToMany
使用实体 A 和 B 之间的 a 映射了一个双向关系JoinTable
,如下所示。
A类:
@Entity
@Audited
public class A {
// Other stuff
@OneToMany()
@Cascade(CascadeType.ALL)
@LazyCollection(LazyCollectionOption.TRUE)
@JoinTable(name = "A_B", joinColumns = { @JoinColumn(name = "A_ID") }, inverseJoinColumns = { @JoinColumn(name = "B_ID") })
private Set<B> setOfBs;
// Getters + Setters + HashCode + Equals
}
B类:
@Entity
@Audited
public class B {
// Other stuff
@ManyToOne(optional=true)
@LazyCollection(LazyCollectionOption.TRUE)
@JoinTable(name = "A_B", joinColumns = { @JoinColumn(name = "B_ID") }, inverseJoinColumns = { @JoinColumn(name = "A_ID") })
private A a;
// Getters + Setters + HashCode + Equals
}
通过 a 持久化具有一组 B 的 A 实体时没有问题save()
。即使没有明确设置 B 和 A 之间的双向关系。当 Envers 进行插入以将修订保存在JoinTable
aud 表中时出现此异常:
Hibernate: insert into a_b_AUD (a_id, b_id, REV) values (?, ?, ?)
16:27:38,051 TRACE BasicBinder:70 - binding parameter [1] as [BIGINT] - <null>
16:27:38,051 TRACE BasicBinder:82 - binding parameter [2] as [BIGINT] - 2038
16:27:38,051 TRACE BasicBinder:82 - binding parameter [3] as [INTEGER] - 2039
16:27:38,056 WARN JDBCExceptionReporter:233 - SQL Error: 0, SQLState: 23502
16:27:38,056 ERROR JDBCExceptionReporter:234 - ERROR: null value in column «a_id» violates not null restriction
如果我在 Hibernate 中设置完整的调试模式,我可以看到 Envers“知道”该 Id 但没有将其传递给插入。我该如何解决这个问题?关系是否正确映射?Envers 需要一些特殊的配置。管理这个?
此致。