import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
@Entity
@Table(name="t_student")
public class Student{
private int id;
private String name;
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
@Entity
@Table(name="t_teacher")
public class Teacher{
private int id;
private String name;
pricate Set<Student> students;
@ManyToMany
@JoinTable(name="t_s",
joinColumns={@JoinColumn(name="teacher_id)},
inverseJoinColumns={@JoinColumn(name="student_id)}
)
public Set<Student> getStudents() {
return students;
}
public void setStudents(Set<Student> students) {
this.students= students;
}
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
这时候会生成一张中间表t_ s, 里面会有teacher _ d和students _ id两个字段,字段名字均由注解
@JoinTable(name=”t_s”,
joinColumns={@JoinColumn(name=”teacher_id)},
inverseJoinColumns={@JoinColumn(name=”student_id)} )
joinColumns是指本表的对应的外键id
inverseJoinColumns是指对方那张表的对应的外键id