歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

Hibernate關聯映射 --- 多對多實例分析(單向關聯)

一 思路分析

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>

Copyright © Linux教程網 All Rights Reserved