Hibernate学习小结之实体对象之间关系

来源:互联网 发布:服装erp软件排行 编辑:程序博客网 时间:2024/05/18 02:11

双向一对一关系:
实体对象之间一对一的关联是通过数据库的外键实现的
外键的使用有以下两种方式:
主键关联:      不需要借助额外字段,直接通过两个表的主键来关联,两表中相关联的记录要使用相同的主键值
唯一外键关联 :某个表的外键字段关联到另一个表的主键字段上,是多对一关联的特例

主键关联:
首先需要在Student对象的配置文件中定义到Address对象的关联:
<one-to-one name="address" class="Address" ></one-to-one>
然后需要在Address对象的配置文件中定义到Student对象的关联
<one-to-one name="student" class="Student" cascade="all"></one-to-one>
并修改Address对象配置文件的id元素
<id name="id" column="id">
<generator class="foreign">
    <param name="property">student</param>
</generator>
</id>

唯一外键关联:

为每一个Address配给一个Student,形成一对一,address表格通过student_id作为外键参考至student:
Student.hbm.xml文件:
<one-to-one name="address" class="Address" property-ref="student" ></one-to-one>

在<one-to-one>中,property-ref告诉Hibernate,查询出 address 并将其参考至 student
Address.hbm.xml文件:
<many-to-one name="student" class="Student" column="student_id" unique="true" fetch="join" ></many-to-one>

unique="true":使多对一变成一对一

在多的一端加入一个外键,参考一的一端,加载多的一端,一的一端自动加载进来


双向一对多关联关系:
Clazz类文件代码如下:
public class Clazz {
private Long id;
private String Name;
private Set<Student> students = new HashSet<Student>();
}

Clazz.hbm.xml文件:
<set name="students" cascade ="save-update" inverse="true" >
<key column="class_id"></key>
<one-to-many class="Student"/>
</set>
cascade="save-update":操作时的级联关系,在执行save和update时进行级联操作
一般讲cascade配置在one-to-many(one的一方),和one-to-one(主对象一方)
inverse="true":使“多”的一方变为主控方,用在双向关联关系中
column="class_id":指定关联方与本类关联的外键字段
class="Student":关联的目标类
<set>的常用属性如下:
name    映射类属性的名字
lazy    是否采用迟延加载
inverse    标识双向关联中被动的一方,为true时表示控制方为对方
<key>元素是<set>的子元素,必不可少,用于描述两者之间的关联关系
<key>元素的常用属性:
column        父元素所持有的类所对应表的外键字段名
on-delete    外键关联是否打开数据库级别的级联删除,noaction|cascade
not-null    表明外键字段是否可以为空,true|false
update    表明外键是否可以被更新,true|false
unique    表明外键是否有唯一性约束,true|false

Student类文件修改如下:
public class Student {
private Long id;
private String name;
private Integer age;
private Clazz clazz;
private Address address;
}
Student.hbm.xml文件:
<many-to-one name="clazz" class="Clazz“ column="class_id">
</many-to-one>
<one-to-one name="address" class="Address" property-ref="student"></one-to-one>

 

多对多关联关系:
多对多在这里表示为:many-to-many
实现多对多需要一个中间表

班级Clazz的配置
    <set name="teachers" table="class_teacher " cascade=“all“ inverse=“true”>
         <key column="class_id"></key>
         <many-to-many class="entity.Teacher" column="teacher_id“  />
    </set>

教师Teacher的配置
    <set name="classes" table="class_teacher ">
        <key column="teacher_id"></key>
        <many-to-many class="entity.Clazz" column="class_id"/>
    </set>

原创粉丝点击