当前位置: 移动技术网 > IT编程>开发语言>Java > Hibernate映射解析之关联映射详解

Hibernate映射解析之关联映射详解

2019年07月22日  | 移动技术网IT编程  | 我要评论
hibernate中的关联映射 关联关系 平时开发中,类与类之间最普遍的的关系就是关联关系,而且关联是有方向的。 以部门(dept)和员工(employee)

hibernate中的关联映射

关联关系

平时开发中,类与类之间最普遍的的关系就是关联关系,而且关联是有方向的。
以部门(dept)和员工(employee)为例:一个部门下有多个员工,而一个员工只能属于一个部门。

从employee到dept的关联就是 多对一 关联。 这就说明 每个employee对象只会引用一个dept对象,因此在employee类中应该定义一个dept类型的属性,来引用所关联的dept对象。

从dept到employee的关联就是 一对多 关联。这就说明 每个dept对象会引用一组employee对象,因此应该在employee类中定义一个集合类型的属性,来引用所有关联的employee对象。

如果仅有从employee到dept的关联或者仅有从dept到employee的关联,就称为单向关联。
如果同时包含两种关联,就是双向关联。

单向关联

双向关联

配置多对一的关联关系

  1. 以员工和部门为例,配置 员工到部门的单向多对一关联
  2. 在employee类中定义dept类型的属性 dept;

配置文件中配置 使用'many-to-one'进行配置

private integer id;
private string name;
private integer age;
private integer sex;
private dept dept; //引用所属的部门

映射文件

<many-to-one name="dept" column="dept" class="com.ytzl.demo.entity.dept" cascade="save-update"></many-to-one>
  1. name :属性名 这里就是 employee中的dept
  2. column:外键字段 ,这里就是employee表里的dept字段
  3. class :dept属性对应的类型 ,这里是 dept类
  4. cascade:级联操作 这里是 保存和修改

配置一对多的关联关系

以员工和部门为例 ,从部门到员工的关联就是 一对多的关联

  1. 在dept类中增加集合属性用来保存所引用的员工对象
  2. 在映射文件中配置 set

修改类属性

private integer id;
private string name;
private set<employee> employees = new hashset<>(); //用来保存员工引用

修改映射文件

<!-- 配置一对多的关联 -->
<set name="employees"> <!-- name 对应的属性名 就是集合的名字 -->
 <key column="dept"></key> <!-- 对应的是 employee表的外键字段名 -->
 <one-to-many class="com.ytzl.demo.entity.employee"/> <!-- 关联的类 这里是 员工类 -->
</set>
  1. name :属性名 ,集合属性的名字
  2. key元素:column 属性 设定与所关联的持久化类对应的表的外键,这里是employee表的dept外键字段名
  3. one-to-many :class属性指定关联的持久化类 这里对应的是员工类

cascade 属性 关联操作

用于指定如何操作与当前对象关联的其他对象

可选值:

  1. none :默认值 ;不关联其他的对象
  2. save-update 当通过session执行 save() ,update()saveorupdate()方法的时候级联更新或者保存所关联的对象
  3. delete :当通过session的delete()删除当前对象时,会级联 删除关联对象;
  4. all :包含 delete,save-update的行为

inverse属性 反转属性

在hibernate中,'inverse'属性指定了关联关系中的方向。

关联关系中,'inverse=”false”‘的为主动方,由主动方负责维护关联关系。

order-by属性 指定集合内元素的排序顺序

这里以员工和部门为例,部门内的员工要以年龄倒序的顺序排序,就可以通过设置 order-by属性

order-by="age desc"

多对多关联

以 员工和项目为例,一个员工可以参与到多个项目中,每个项目有多个员工的参于

  1. 配置 project类 ,在类中添加集合属性 用于保存员工引用
  2. 配置employee类,在类中添加集合睡醒,用于保存项目引用

往往多对多映射涉及到第三张表

project类

private integer id;
private string name;
private set<employee> employees = new hashset<>();

配置project映射类

<?xml version="1.0" encoding="utf-8"?>
<!doctype hibernate-mapping public 
 "-//hibernate/hibernate mapping dtd 3.0//en"
 "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 
 <hibernate-mapping>
 <class name= "com.ytzl.demo.entity.project" table ="project" dynamic-update="true">
 <id name="id" column="p_id" type="java.lang.integer">
 <generator class="increment"></generator>
 </id>
 <property name="name" column="p_name" type="java.lang.string"></property>
 <set name="employees" table="emp_pro_relate" cascade="save-update">
 <key column="pro_id"></key>
 <many-to-many class="com.ytzl.demo.entity.employee" column="emp_id"></many-to-many>
 </set>
 </class>
 </hibernate-mapping>
  1. set元素的table属性 对应第三张关联表
  2. key元素的column属性 对应project表在第三张表的外键
  3. many-to-many 元素 column对应关联对象在第三张表的外键

employee类

private integer id;
private string name;
private integer age;
private integer sex;
private dept dept; //引用所属的部门
private set<project> projects = new hashset<>(); //保存项目引用

employee映射文件

<set name="projects" table="emp_pro_relate" inverse="true">
 <key column="emp_id"></key>
 <many-to-many class="com.ytzl.demo.entity.project" column="pro_id"></many-to-many>
</set>

延迟加载

当hibernate从数据库中加载dept对象时,如果同时加载所有关联的employee对象,而我们仅仅需要dept对象,那么这些关联的对象就白白浪费了许多内存空间,这时就有了延迟加载,如果实际需要用到employee时再去加载。hibernate使用lazy属性指定延迟加载的查询策略

hibernate允许在对象-关系映射文件中配置加载策略

级别 说明
类级别 元素中lazy属性可选值为 true(延迟加载)和false(立即加载);默认值是true;
一对多关联级别 元素中lazy属性的可选值为 :true(延迟加载) ,extra(增强延迟加载),false(立即加载) 默认值为 true
多对一关联级别 元素中lazy属性的可选值为 :proxy(延迟加载),no-proxy(无代理延迟加载),和false(立即加载) ;默认值为 proxy

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网