Как сопоставить @ManyToOne
связь с использованием не-первичного ключа в Hibernate? Я могу использовать аннотацию @NaturalId
, но подоконник имеет ошибку:
A Foreign key refering POJO.Question from POJO.Answer has the wrong number of column. should be 4
Класс вопроса (с несколькими первичными ключами):
@Entity
@Table(name = "[dbo].[Question]")
public class Question implements Serializable {
@Column(name = "[Id]", unique = true, nullable = false)
@GeneratedValue(strategy = GenerationType.IDENTITY)
@NaturalId
private Integer id;
@EmbeddedId
private QuestionEmbeddable questionEmbeddable;
}
Первичный ключ
public class QuestionEmbeddable implements Serializable{
@Column(name = "[Development Template Id]")
private int templateId;
//Sekcja w templejcie
@Column(name = "[Section]")
private Integer section;
//Numer w sekcji
@Column(name = "[Number]")
private Integer number;
//Wersja
@Column(name = "[Version]")
private Integer version;
}
Класс ответа:
@Entity
@Table(name = "[dbo].[Answer]")
public class Answer implements Serializable {
@Id
@Column(name = "[Id]", unique = true, nullable = false)
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@JoinColumn(name = "[Question Id]")
@ManyToOne(fetch=FetchType.LAZY)
private Question question;
Похоже, что связь по-прежнему @EmbeddedId
вместо @Naturalid
. Я не знаю почему?