1. 多对多(Teacher – Student)的单向关联
首先考虑一个老师可以有多个学生的问题
2. 多对多可以看成两个多对一,从多对多的分析上来看,如果从多个老师中查找多个学生,
不管是通过学生的id还是通过的是老师的id都会有冗余,所以最好有个中间表来关联这两张表,中间表中有两列,分别是老师的id和学生的id
二 代码分析
1.Teacher类,在单向关联中多对多中是一的一方
package com.hbsi.domain;
import java.util.Set;
//单向一对多 Teacher 一 对 多 Student
public class Teacher {
private int id;
private String name;
private Set<Student> students;//一个老师可以有多个学生
public Teacher() {
super();
// TODO Auto-generated constructor stub
}
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;
}
public Set<Student> getStudents() {
return students;
}
public void setStudents(Set<Student> students) {
this.students = students;
}
}
2.Studenet类 相对于一的一方多的一方
package com.hbsi.domain;
import java.util.Set;
public class Student {
private int id;
private String name;
public Student() {
super();
// TODO Auto-generated constructor stub
}
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;
}
}
3. 在Teacher中的映射文件 Teacher.hbm.xml文件
此映射文件因为是多对一,所以建表的时候在这里建一个中间表用来关联这两个表
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.hbsi.domain">
<class name="Teacher" table="teacher">
<id name="id" column="id">
<generator class="native" />
</id>
<property name="name" column="name" />
<!-- 集合属性的体现 多对多 table属性指定的是中间表的名字 -->
<set name="students" table="teacher_student">
<!--查老师的id的 和中间表联系-->
<key column="teacher_id"/>
<!-- 查学生的id和中间表的关系 -->
<many-to-many class="Student" column="student_id"></many-to-many>
</set>
</class>
</hibernate-mapping>