Hibernate と Envers 4.2.1.Final バージョンを使用しています。私が確認したい問題は、関係が確立されていないときに Envers が監査ジョイント可能オブジェクトにデータを挿入しようとしていることです。次のようにマッピングされた OneToOne 双方向関係があります。
エンティティ A:
@Entity
@Audited
public class A {
@Id
@GeneratedValue
private Long id;
@OneToOne(optional = true)
@JoinTable(name = "A_B", joinColumns = { @JoinColumn(name = "a_id", unique = true) }, inverseJoinColumns = { @JoinColumn(name = "b_id") })
private B b = null;
// Getters + Setters + HashCode + Equals
}
エンティティ B:
@Entity
@Audited
public class B {
@Id
@GeneratedValue
private Long id;
@OneToOne(mappedBy = "b", optional=true)
private A a = null;
// Getters + Setters + HashCode + Equals
}
JoinTables の生成された DDL は次のとおりです。
JoinTable A_B:
CREATE TABLE public.a_b (
b_id BIGINT,
a_id BIGINT NOT NULL,
CONSTRAINT a_b_pkey PRIMARY KEY(a_id),
CONSTRAINT fk_32f8f6e4ba7d48728bfb376dd19 FOREIGN KEY (a_id)
REFERENCES public.a(id)
ON DELETE NO ACTION
ON UPDATE NO ACTION
NOT DEFERRABLE,
CONSTRAINT fk_6c0d47b64ad3462aaab3813ccae FOREIGN KEY (b_id)
REFERENCES public.b(id)
ON DELETE NO ACTION
ON UPDATE NO ACTION
NOT DEFERRABLE
) WITHOUT OIDS;
JoinTable A_B_AUD (Envers 用):
CREATE TABLE public.a_b_aud (
b_id BIGINT NOT NULL,
rev INTEGER NOT NULL,
a_id BIGINT NOT NULL,
CONSTRAINT a_b_aud_pkey PRIMARY KEY(a_id, rev),
CONSTRAINT fk_5689e745b66c4ee2a8822e44079 FOREIGN KEY (b_id, rev)
REFERENCES public.b_aud(id, rev)
ON DELETE NO ACTION
ON UPDATE NO ACTION
NOT DEFERRABLE,
CONSTRAINT fk_b5c868c4f5f34d35bdb7a6c1281 FOREIGN KEY (a_id, rev)
REFERENCES public.a_aud(id, rev)
ON DELETE NO ACTION
ON UPDATE NO ACTION
NOT DEFERRABLE
) WITHOUT OIDS;
A エンティティを作成して永続化するときの SQL ステートメントは次のとおりです。
Hibernate: select nextval ('hibernate_sequence')
Hibernate: insert into A (id) values (?)
12:58:50,488 TRACE BasicBinder:84 - binding parameter [1] as [BIGINT] - 21
Hibernate: select nextval ('hibernate_sequence')
Hibernate: insert into revinfo (timestamp, usuarioId, id) values (?, ?, ?)
12:58:50,506 TRACE BasicBinder:84 - binding parameter [1] as [BIGINT] - 1370948330497
12:58:50,506 TRACE BasicBinder:72 - binding parameter [2] as [BIGINT] - 0
12:58:50,507 TRACE BasicBinder:84 - binding parameter [3] as [INTEGER] - 22
Hibernate: insert into A_AUD (REVTYPE, id, REV) values (?, ?, ?)
12:58:50,509 TRACE BasicBinder:84 - binding parameter [1] as [INTEGER] - 0
12:58:50,509 TRACE BasicBinder:84 - binding parameter [2] as [BIGINT] - 21
12:58:50,510 TRACE BasicBinder:84 - binding parameter [3] as [INTEGER] - 22
Hibernate: insert into A_B_AUD (b_id, a_id, REV) values (?, ?, ?)
12:58:50,514 TRACE BasicBinder:72 - binding parameter [1] as [BIGINT] - <null>
12:58:50,515 TRACE BasicBinder:84 - binding parameter [2] as [BIGINT] - 21
12:58:50,515 TRACE BasicBinder:84 - binding parameter [3] as [INTEGER] - 22
12:58:50,518 WARN SqlExceptionHelper:145 - SQL Error: 0, SQLState: 23502
12:58:50,518 ERROR SqlExceptionHelper:147 - ERROR: null value for the column «b_id» violates not null restriction
...
ご覧のとおり、A インスタンスで関係が確立されておらず (null 初期化)、Envers 用に生成されたスキーマに Not Null 制限がある場合、Envers は aud ジョイント可能にエントリを挿入しようとしています。JIRA を開く前にこの動作を確認できる人もいますか?