hibernate

來源:STCore.com 收集整理   發佈日期:2006-11-13  進入論壇
<script src="http://pagead2.googlesyndication.com/pagead/show_ads.js" type="text/javascript"> </script>
前言
以下所有描述以選課系統這個案例來說明。在一個選課系統中,基本的對象有課題(Course)、教師(Teacher)和學生(Student)。
 
一、一對一關聯(有共享主鍵關聯和惟一外鍵關聯兩種)
1、共享主鍵關聯
 
比如課題是由教師去任教,沒有教師就沒有課題,這樣課題就可以完全由教師來決定。
 
Java示例代碼如下:
 
publicclass Course {
    private Long id;
 
    private String name;
 
    private Teacher teacher;
    // 省略settergetter 方法
}
 
publicclass Teacher {
    private Long id;
 
    private String name;
 
    private Course course;
    // 省略settergetter 方法
}
 
配置文件
Teacher.hbm.xml
<!-- cascade="all" 表明對Teacher對象CRUD的操作會級聯到Course對象 -->
<one-to-one name="course" class="powerwind.bean.Course"
    cascade="all" />
Course.hbm.xml
<!-- id值參照 teacher屬性而生成-->
<id name="id" type="java.lang.Long" column="id">
    <generator class="foreign">
       <param name="property">teacher</param>
    </generator>
</id>
<!-- teacher屬性參照 -->
<one-to-one name="teacher" class="powerwind.bean.Teacher"
           constrained="true" />
 
2、惟一外鍵關聯
外鍵關聯需要一個定義外鍵字段,比如在教師表定義一個課題的外鍵 course_id。
 
配置文件
Teacher.hbm.xml
<many-to-one name="course" class="powerwind.bean.Course"
       column="course_id" cascade="save-update" unique="true"/>
如果同時在Coure.hbm.xml加上如下配置則爲雙向關聯。
<one-to-one name="teacher" class="powerwind.bean.Teacher"
       property-ref="course" />
 
3、第三種
以上兩種一對一關聯在Hibernate中是比較常用的。但我用另外一種方法實現時,發現也可行。測試了一下,目前沒有發現錯誤。
思想是和唯一外鍵關聯相似,但兩個表中都需要一個外鍵,在配置<one-to-one>的地方用了<many-to-one>,即兩邊對用了<many-to-one>
 
Course.hbm.xml
<many-to-one name="teacher" class="powerwind.bean.Teacher"
           column="teacher_id" unique="true" />
Teacher.hbm.xml
<many-to-one name="course" class="powerwind.bean.Course"
           column="course_id" unique="true" />
 
細看起來,應該是一對多關聯的配置,只是兩邊都設置“一”,欺騙了hibernate。在hibernate文檔中有這樣一句:
基於外鍵關聯的單向一對一關聯和單向多對一關聯幾乎是一樣的。唯一的不同就是單向一對一關聯中的外鍵字段具有唯一性約束。
二、一對多、多對一關聯
一對多(多對一)的關聯是現在中用得比較多的。現實中,一個教師是可以任教多個課程的,這就是典型的一對多關係。(由於關聯是有方向的,一對多和多對一的單向關聯是不同的,而雙向的時候就一樣)
單向關聯:
假設我們只需要從課題知道該課題的任教教師是誰?而不需要從教師那裏知道該都任教哪些課程。只在Course.hbm.xml中這樣設置就可以。
<many-to-one name="teacher" class="powerwind.bean.Teacher"
           column="teacher_id" />
如果只需要從教師那裏得知他的所有課程,可把原本多對多的關聯變成一對多(需要連接表Teacher_ Course)。
Teacher.hbm.xml
<set name="courses" table="teacher_course" cascade="save-update">
      <key column="teacher_id"/>
      <many-to-many column="course_id"
            unique="true" class="powerwind.bean.Course"/>
</set>
unique="true"是它不同於多對多的地方。
 
雙向關聯:
雙向關聯就是在單向的基礎上,再配置多一項(向)。
 
最常用最標準的配置是這種:
Course.hbm.xml
<many-to-one name="teacher" class="powerwind.bean.Teacher"
           column="teacher_id" />
Teacher.hbm.xml
<set name="courses" inverse="true">
       <key column="course_id" not-null="true" />
       <one-to-many class="powerwind.bean.Course" />
</set>
其中inverse="true" 的設置是比較常用的,設置後,當Teacher和Course對象狀態均發生變化時,僅參照Course對象狀態的變化來更新數據厙。
三、多對多關聯
舉個單向多對多關聯的例子。比如遠程教學,教師不知道他的學生有誰誰誰,只知道有很多學生在遠程聽課;而學生可以知道他的老師有哪些。這樣,不就是單向多對多關聯嗎?實際上,單向的多對多關聯是不完整的雙向多對多關聯。
 
如果單向,則只要在Student.hbm.xml配置。
<set name="teachers" inverse="true" table="student_teacher">
    <key column="student_id" />
    <many-to-many column="teacher_id" class="powerwind.bean.Teacher" />
</set>
如果雙向,在上面的基礎上,還要在Teacher.hbm.xml配置。
<set name="students" table="student_teacher">
    <key column="teacher_id" />
    <many-to-many column=" student_id" class="powerwind.bean.Student" />
</set>
 
有時候,連接表還會有其它信息的。比如學生與課程的關係表(stuent_course),裏面可以加入學生的考試成績。這樣的話,我們可以把這個連接表定義成這樣:
student_coures( id,student_id, course_id, score );
這樣,雙向多對多關聯就變成兩個一對多的關聯。這種情況下,多對多的雙方並沒有直接擁有對方的集合引用。這裏把student_coures 表對應的實體叫 Score (一時想不出,叫成績單算了)。
Student.hbm.xml
<set name="scores" inverse="true">
       <key column="student_id" />
       <one-to-many class="powerwind.bean.Score" />
</set>
Teacher.hbm.xml
<set name="scores" inverse="true">
       <key column="teacher_id" />
       <one-to-many class="powerwind.bean.Score" />
</set>
 
Score.hbm.xml
<many-to-one name="teacher" column="teacher_id"
       class="powerwind.bean.Teacher" />
<many-to-one name="student" column="student_id"
class="powerwind.bean.Student" />
 
發佈了36 篇原創文章 · 獲贊 0 · 訪問量 8萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章