在设计数据库时我们会考虑,表与表之间的关系,例如我们前边经常提到的一对一,一对多,多对多关系,在数据库中我们通过外键,第三张表等来实现这些关系。而Hibernate时间实体类和数据库中的表进行的映射,这些关系如何映射呢?这里简单总结一下:

一,一对多,多对一关系映射,这里拿学生和班级进行简单演示:

1,学生的类和对应的映射文件的编写:

  1. private int sid ;
  2. private String sname ;
  3. private Classes classes ; //,引入班级对象,多对一
  1. <class name="com.ljh.hibernate.pojo.Student" table="t_student" lazy="false">
  2. <id name="sid" column="sid">
  3. <generator class="native"/>
  4. </id>
  5. <property name="sname" column="sname" type="java.lang.String" length="20" not-null="true"/>
  6. <!--
  7. 表示对象的关系:多对一
  8. name 表示当前类的关系对象
  9. column 表示数据库中外键字段(也是描述数据关系)
  10. class 表示name属性值的类型
  11. cascade 级联
  12. 主动方所做的操作(insert,update,delete),被动方也跟着做相同的操作。
  13. 取值:save-update、delete 、all
  14. save-update : 保存或更新当前对象时,级联保存或更新关联对象
  15. delete : 删除当前对象时,级联删除关联对象
  16. all : 包含save,update,delete三种操作。
  17. 对于多对一的场合,级联不能使用delete和all,否则会违背数据关系完整性。
  18. lazy : 延迟加载
  19. 延迟初始化对象信息,等使用对象时再查询数据库。
  20. false : 禁用延迟加载
  21. proxy : 使用延迟加载(默认值),采用cglib代理完成延迟加载的扩展功能。
  22. no-proxy :  不使用代理,完成延迟加载 。可以使用第三方字节码增强工具。
  23. fetch : 数据抓取策略  :根据主动方,查询被动方时所采用的查询方式。
  24. fetch="select" 默认值,会采用多条语句的方式查找,往往会延迟加载数据
  25. fetch="join"  默认会采用左连接查询数据,不会延迟加载数据。
  26. not-null 如果取值为true,那么框架采用内连接查询数据。
  27. -->
  28. <many-to-one name="classes" column="cid" cascade="save-update" lazy="no-proxy" fetch="join" not-null="true" class="com.ljh.hibernate.pojo.Classes"></many-to-one>
  29. </class>

2,班级的实体类和对应的映射文件:

  1. private int cid ;
  2. private String cname ;
  3. private Set<Student> studentSet = new HashSet<Student>(); //引入学生类的集合,一对多
  1. <class name="com.ljh.hibernate.pojo.Classes" table="t_classes" >
  2. <id name="cid" column="cid">
  3. <generator class="native"/>
  4. </id>
  5. <property name="cname" column="cname" type="java.lang.String" length="20" not-null="true"/>
  6. <!-- 声明   一对多映射
  7. lazy : 延迟加载
  8. false : 禁用延迟加载
  9. true : 延迟加载(默认值)
  10. extra : 支持延迟加载的。(推荐)
  11. 当获取集合自身信息时,可以发送高效的查询语句。
  12. 例如:只希望获取集合的长度,而不需要获取集合中数据的信息,框架会通过函数执行查询进行计算集合长度。。
  13. fetch : 数据抓取策略
  14. 查询关联对象的数据时,所采用的查询方式。
  15. join : 通过一条连接语句进行立即查询。(延迟加载不起作用)
  16. select : 通过多条查询语句进行查询。
  17. subselect : 通过子查询语句进行立即查询。  (不推荐使用)(默认情况下和select取值结果相同)
  18. not-null="true" 对于一对多的查询,即使设置了not-null语句,依然采用左连接查询。
  19. Inverse="true",表示控制反转,由对方也就是学生方来进行管理外键。因为外键在学生
  20. -->
  21. <set name="studentSet" cascade="all" inverse="true" fetch="subselect">
  22. <key column="cid" not-null="true"></key>
  23. <one-to-many class="com.bjpowernode.hibernate.pojo.Student"/>
  24. </set>
  25. </class>

二,自关联:就是在自己的类进行关联自己,例如父菜单与子菜单的关系,对应的实体类,和映射文件

  1. private int mid ;           private String name ;
  2. private Set<Menu> menuSet = new HashSet<Menu>(); //父菜单与子菜单的关系为:一对多
  3. private Menu pmenu ; //子菜单和父菜单的关系为:多对一
  1. <class name="com.ljh.hibernate.pojo.Menu" table="t_menu" >
  2. <id name="mid" column="mid">
  3. <generator class="native"/>
  4. </id>
  5. <property name="name" column="name" type="java.lang.String" length="20" not-null="true"/>
  6. <many-to-one name="pmenu" column="m_id" cascade="save-update"></many-to-one>
  7. <!--
  8. 自关联表的设计:外键字段不能为非空。
  9. -->
  10. <set name="menuSet" cascade="all" inverse="true">
  11. <key column="m_id"></key>
  12. <one-to-many class="com.ljh.hibernate.pojo.Menu"/>
  13. </set>
  14. </class>

三,一对一关系映射:

1,假如是主键一对一用来映射:也就是说被动方的主键是来自于主动方的主键,也可以将之称之为外键:

类之间相互添加彼此的应用。

映射文件中主动方,增加一对一标签:

  1. <one-to-one name="userinfo" cascade="all" class="com.ljh.hibernate.pojo.UserInfo"></one-to-one>
  2. 被动方,主键又是外键,也添加一对一的映射标签:
  3. <id name="uid" column="uid">
  4. <generator class="foreign">
  5. <param name="property">user</param>
  6. </generator>
  7. </id>
  8. <!--
  9. 描述一对一关系关系映射
  10. constrained="true" : 表示强制要求一对一使用外键关联。增加外键约束。
  11. -->
  12. <one-to-one name="user" constrained="true"  class="com.ljh.hibernate.pojo.User"></one-to-one>

2,使用外键约束,其实是多对一的特殊情况,例如学生对班级,

类添加彼此的应用。

映射文件中学生端主动端,添加外键进行约束,添加多对一标签,

  1. <!--
  2. unique : 唯一约束
  3. 如果外键含有unique约束,那么表示主动方和被动方的关系为一对一。
  4. 对于一对一映射来讲,可以设置级联关系为delete 和 all
  5. 根据主动方查询被动方关联数据,是支持延迟加载的。
  6. -->
  7. <many-to-one name="classes" column="cid" unique="true" cascade="all" class="com.ljh.hibernate.pojo.Classes"></many-to-one>
  8. 班级端的映射文件:添加一对一的标签:
  9. <one-to-one name="student" cascade="all" property-ref="classes" class="com.ljh.hibernate.pojo.Student"></one-to-one>

四,多对多的关系,例如学生对课程的对应,在数据库中会生成第三张表进行维护:

在各自的类中引入对方的set集合,表示多对多。

学生端:

  1. <set name="courseSet" table="t_student_course" cascade="save-update">
  2. <key column="sid"></key>
  3. <many-to-many class="com.ljh.hibernate.pojo.Course" column="cid"></many-to-many>
  4. ;/set>

课程端:

  1. <!--
  2. 对于多对多来讲,级联只能设置cascade="save-update"是合理的
  3. inverse="true" 让集合一端去维护中间表数据。任意一端都可以。
  4. -->
  5. <set name="studentSet" table="t_student_course"  cascade="save-update"  inverse="true">
  6. <key column="cid"></key>
  7. <many-to-many class="com.ljh.hibernate.pojo.Student" column="sid"></many-to-many>
  8. </set>

五,联合主键的映射,这种情况很少见,看一下如何吧,

出现了这种联合键时,需要我们为其定义一个联合主键的类(实现Serializable接口),类中声明多个字段的属性,表示联合主键字段。

在配置映射文件时,主键的配置利用联合主键的标签即可:

  1. composite-id name="id">              <key-property name="title"></key-property>
  2. <key-property name="author"></key-property>
  3. </composite-id>

综上,为Hibernate中对数据库进行关联设置映射时的几个简单例子,主要是我们根据实际情况,掌握几个对应标签的使用,还有就是里边的属性的使用。像lazy,cascade,fetch等等。注意观察其中的不同。这样进行了关联设置我们就可以很好的,根据类生成数据库,对数据库中的数据进行关联操作,更加合理化!

Hibernate框架(三)框架中的关系映射的更多相关文章

  1. JavaEE之Hibernate(开放源代码的对象关系映射框架)

    Hibernate(开放源代码的对象关系映射框架) 1.简介 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全 ...

  2. Android数据库框架——GreenDao轻量级的对象关系映射框架,永久告别sqlite

    Android数据库框架--GreenDao轻量级的对象关系映射框架,永久告别sqlite 前不久,我在写了ORMLite这个框架的博文 Android数据库框架--ORMLite轻量级的对象关系映射 ...

  3. Android数据库框架——ORMLite轻量级的对象关系映射(ORM)Java包

    Android数据库框架--ORMLite轻量级的对象关系映射(ORM)Java包 事实上,我想写数据库的念头已经很久了,在之前写了一个答题系统的小项目那只是初步的带了一下数据库,数据库是比较强大的, ...

  4. Hibernate(三)——框架中的关系映射

    在设计数据库时我们会考虑,表与表之间的关系,例如我们前边经常提到的一对一,一对多,多对多关系,在数据库中我们通过外键,第三张表等来实现这些关系.而Hibernate时间实体类和数据库中的表进行的映射, ...

  5. Hibernate(开放源代码的对象关系映射框架)

    Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自 ...

  6. Hibernate框架之双向多对多关系映射

    昨天跟大家分享了Hibernate中单向的一对多.单向多对一.双向一对多的映射关系,今天跟大家分享下在Hibernate中双向的多对多的映射关系 这次我们以项目和员工举个栗子,因为大家可以想象得到,在 ...

  7. Hibernate 中对象关系映射(ObjectRelationMapping)

    1.什么是对象关系映射? 解析:对象-关系映射(Object Relational Mapping,简称ORM,对象关系映射)是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说, ...

  8. Hibernate学习笔记(四)关系映射之一对一关联映射

    一. 一对一关联映射 ²        两个对象之间是一对一的关系,如Person-IdCard(人—身份证号) ²        有两种策略可以实现一对一的关联映射 Ø        主键关联:即让 ...

  9. Hibernate学习笔记(五) — 多对多关系映射

    多对多关系映射 多对多建立关系相当于在第三张表中插入一行数据 多对多解除关系相当于在第三张表中删除一行数据 多对多改动关系相当于在第三张表中先删除后添加 多对多谁维护效率都一样.看需求 在实际开发过程 ...

随机推荐

  1. Linux中级之lvs三个模式的图像补充(nat,dr,tun)

    负载均衡(Load Balance)集群提供了一种廉价.有效.透明的方法,来扩展网络设备和服务器的负载.带宽.增加吞吐量.加强网络数据处理能力.提高网络的灵活性和可用性. (1)单台计算机无法承受大规 ...

  2. Mac 使用 Parallels Desktop 虚拟机安装 win10 教程

    Parallels Desktop 介绍 Parallels Desktop 是一款运行在 Mac 电脑上的极为优秀的虚拟机软件,用户可以在 Mac OS X下非常方便运行 Windows.Linux ...

  3. Jquery ajax 详解(Day_16)

    太在意别人的看法最后会有两种结局,要么自己累死,要么让别人整死. 简介 AJAX 是与服务器交换数据的技术,它在不重载全部页面的情况下,实现了对部分网页的更新. 简短地说,在不重载整个网页的情况下,A ...

  4. 解决mysql无法远程连接的问题

    前言 最近开发中遇到一个问题,mysql在服务器本地可以登录,但是远程通过3306端口却不可以.这个问题困扰了我一周之久,终于在今天解决了.在解决的过程中试了很多的方法,遂记录下来,希望能给大家一些提 ...

  5. GO学习-(6) Go语言基础之运算符

    Go语言基础之运算符 运算符用于在程序运行时执行数学或逻辑运算. 运算符 Go 语言内置的运算符有: 算术运算符 关系运算符 逻辑运算符 位运算符 赋值运算符 算数运算符 运算符 描述 + 相加 - ...

  6. 蓝牙mesh网络技术的亮点

    蓝牙mesh网络技术的亮点 The highlights of Bluetooth mesh networking technology 导言 蓝牙是当今最主要的低功耗无线技术之一,对无线设备用户和开 ...

  7. 反应式系统实现MQTT客户机

    反应式系统实现MQTT客户机 Implementing an MQTT client for reactive systems MQTT Reactive是从LiamBindle的MQTT-C库派生的 ...

  8. NX二次开发】Block UI 体收集器

    属性说明 属性   类型   描述   常规           BlockID    String    控件ID    Enable    Logical    是否可操作    Group    ...

  9. Kubernetes 实战——有状态应用(StatefulSet)

    一.简介 有状态实例:新实例和旧实例需要有相同的名称.网络标识和状态 无状态实例:可随时被替换 1. ReplicaSet 和有状态 Pod ReplicaSet 通过 Pod 模板创建多个 Pod ...

  10. echarts迁移图动态加载

    迁移图 获取迁移城市的经纬度 可以调用高德的接口,实现根据地名找寻经纬度的方法 #!/usr/bin/env python3 #-*- coding:utf-8 -*- ''' 利用高德地图api实现 ...