package com.hibernate.entity;
import java.io.Serializable;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
@Entity
public class Student implements Serializable {
/**
*
*/
private static final long serialVersionUID = 3543286868313801941L;
private int id;
private String name;
// private Set<Teacher> teachers = new HashSet<Teacher>();
@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;
}
// @ManyToMany
// public Set<Teacher> getTeachers() {
// return teachers;
// }
//
// public void setTeachers(Set<Teacher> teachers) {
// this.teachers = teachers;
// }
}
package com.hibernate.entity;
import java.io.Serializable;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
@Entity
public class Teacher implements Serializable {
/**
*
*/
private static final long serialVersionUID = 3543286868313801941L;
private int id;
private String name;
private Set<Student> students = new HashSet<Student>();
@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;
}
@ManyToMany
@JoinTable(
name="s_t",
joinColumns=
@JoinColumn(name="teacherid", referencedColumnName="id"),//当前表里的id
inverseJoinColumns=
@JoinColumn(name="studentid", referencedColumnName="id")//与此相对应的表里的id
)
public Set<Student> getStudents() {
return students;
}
public void setStudents(Set<Student> students) {
this.students = students;
}
}
hibernate.cfg.xml和ORMappingTest与之前一样,拷过来就可以使用
当然,.xml中要加
<mapping class="com.hibernate.entity.Teacher" />
<mapping class="com.hibernate.entity.Student" />