Hibernate一对一
前言 以下所有描述以选课系统这个案例来说明。在一个选课系统中,基本的对象有课题(Course)、教师(Teacher)和学生(Student)。
一、一对一关联(有共享主键关联和惟一外键关联两种)
1、共享主键关联 比如课题是由教师去任教,没有教师就没有课题,这样课题就可以完全由教师来决定。 Java示例代码如下:
publicclass Course {
private Long id;
private String name;
private Teacher teacher; // 省略setter和getter 方法
}
publicclass Teacher {
private Long id;
private String name;
private Course course; // 省略setter和getter 方法
}
配置文件Teacher.hbm.xml
<one-to-one name="course" class="powerwind.bean.Course" cascade="all" /> Course.hbm.xml <id name="id" type="java.lang.Long" column="id"> <generator class="foreign"> <param name="property">teacherparam> generator> id> <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中是比较常用的。但我用另外一种方法实现时,发现也可行。测试了一下,目前没有发现错误。 思想是和唯一外键关联相似,但两个表中都需要一个外键,在配置
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对象状态的变化来更新数据厍。
property-ref属性
1.如表Class(ClassID,Class_No,ClassName)与Student(StudentID,studentName,Class_No),
其中ClassID,studentID为主键
两个表是一对多的关系,而要求两个通过ClassNo来关联.
而一般的情况下是通过ClassID,放在student表中作为外键.
2.具体的Hibernate的配置文件如下:
Class.hbm.xml:
<property
name="classNo"
type="java.lang.String"
column="Class_No"
length="30"
/>
<!-- Associations -->
<set name="students"
lazy="false"
inverse="true"
cascade="all-delete-orphan"
>
<key column="Class_No" property-ref="classNo"/>
<one-to-many
class="Student"
/>
</set>
Student.hbm.xml:
<many-to-one
name="class"
class="Class"
not-null="true"
property-ref="classNo"
>
<column name="Class_No" />
</many-to-one>
3.注意点:
property-ref属性一般用来解决遗留数据库One To Many关系的问题
property-ref(可选)被关联到此外键的类中的对应属性的名字,若没指定,使用被关联类的主键.
property-ref=是不是数据库表中的字段名,而是定义的java类中的属性性名,一定要注意.