Welcome 微信登录

首页 / 操作系统 / Linux / Hibernate关联映射 --- 多对多实例分析(单向关联)

一 思路分析1. 多对多(Teacher – Student)的单向关联首先考虑一个老师可以有多个学生的问题 2. 多对多可以看成两个多对一,从多对多的分析上来看,如果从多个老师中查找多个学生,不管是通过学生的id还是通过的是老师的id都会有冗余,所以最好有个中间表来关联这两张表,中间表中有两列,分别是老师的id和学生的id二  代码分析1.Teacher类,在单向关联中多对多中是一的一方package com.hbsi.domain;import java.util.Set;//单向一对多  Teacher 一  对  多  Studentpublic 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>