У меня есть два объекта, которые я хотел бы объединить через несколько столбцов. Эти столбцы разделяются объектом @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?