У меня есть два объекта, которые я хотел бы объединить через несколько столбцов. Эти столбцы разделяются объектом @Embeddable
, который совместно используется обеими объектами. В приведенном ниже примере Foo
может иметь только один Bar
, но Bar
может иметь несколько Foo
(где AnEmbeddableObject
- уникальный ключ для Bar
). Вот пример:
@Entity
@Table(name = "foo")
public class Foo {
@Id
@Column(name = "id")
@GeneratedValue(generator = "seqGen")
@SequenceGenerator(name = "seqGen", sequenceName = "FOO_ID_SEQ", allocationSize = 1)
private Long id;
@Embedded
private AnEmbeddableObject anEmbeddableObject;
@ManyToOne(targetEntity = Bar.class, fetch = FetchType.LAZY)
@JoinColumns( {
@JoinColumn(name = "column_1", referencedColumnName = "column_1"),
@JoinColumn(name = "column_2", referencedColumnName = "column_2"),
@JoinColumn(name = "column_3", referencedColumnName = "column_3"),
@JoinColumn(name = "column_4", referencedColumnName = "column_4")
})
private Bar bar;
// ... rest of class
}
И класс Bar:
@Entity
@Table(name = "bar")
public class Bar {
@Id
@Column(name = "id")
@GeneratedValue(generator = "seqGen")
@SequenceGenerator(name = "seqGen", sequenceName = "BAR_ID_SEQ", allocationSize = 1)
private Long id;
@Embedded
private AnEmbeddableObject anEmbeddableObject;
// ... rest of class
}
Наконец, класс AnEmbeddedObject
:
@Embeddable
public class AnEmbeddedObject {
@Column(name = "column_1")
private Long column1;
@Column(name = "column_2")
private Long column2;
@Column(name = "column_3")
private Long column3;
@Column(name = "column_4")
private Long column4;
// ... rest of class
}
Очевидно, что схема плохо нормализована, это ограничение, что в каждой таблице повторяются поля AnEmbeddedObject
.
Проблема заключается в том, что я получаю эту ошибку, когда я пытаюсь запустить Hibernate:
org.hibernate.AnnotationException: referencedColumnNames(column_1, column_2, column_3, column_4) of Foo.bar referencing Bar not mapped to a single property
Я пробовал отмечать, что JoinColumns не могут быть вставлены и обновлены, но без везения. Есть ли способ выразить это с помощью аннотаций Hibernate/JPA?