Если вы добавляете дополнительные поля в связанную таблицу (STUDENT_COURSE), вы должны выбрать подход в соответствии с ответом скаффмана или другим, как показано ниже.
Существует подход, при котором связанная таблица (STUDENT_COURSE) ведет себя как @Embeddable согласно:
@Embeddable
public class JoinedStudentCourse {
// Lets suppose you have added this field
@Column(updatable=false)
private Date joinedDate;
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="STUDENT_ID", insertable=false, updatable=false)
private Student student;
@ManyToOne(fetch=FetchType.LAZY)
@JoinColumn(name="COURSE_ID", insertable=false, updatable=false)
private Course course;
// getter's and setter's
public boolean equals(Object instance) {
if(instance == null)
return false;
if(!(instance instanceof JoinedStudentCourse))
return false;
JoinedStudentCourse other = (JoinedStudentCourse) instance;
if(!(student.getId().equals(other.getStudent().getId()))
return false;
if(!(course.getId().equals(other.getCourse().getId()))
return false;
// ATT: use immutable fields like joinedDate in equals() implementation
if(!(joinedDate.equals(other.getJoinedDate()))
return false;
return true;
}
public int hashcode() {
// hashcode implementation
}
}
Таким образом, вы будете иметь в классах и студентов, и курсов
public class Student {
@CollectionOfElements
@JoinTable(
table=@Table(name="STUDENT_COURSE"),
joinColumns=@JoinColumn(name="STUDENT_ID")
)
private Set<JoinedStudentCourse> joined = new HashSet<JoinedStudentCourse>();
}
public class Course {
@CollectionOfElements
@JoinTable(
table=@Table(name="STUDENT_COURSE"),
joinColumns=@JoinColumn(name="COURSE_ID")
)
private Set<JoinedStudentCourse> joined = new HashSet<JoinedStudentCourse>();
}
помните: у класса @Embeddable его жизненный цикл привязан к классу сущности-владельца (как ученика, так и курса), поэтому позаботьтесь об этом.
совет: команда Hibernate поддерживает эти два подхода (@OneToMany (ответ Скаффмана) или @CollectionsOfElements) из-за некоторых ограничений в @ManyToMany mapping - каскадная операция.
С уважением,