ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现

Hibernate在实现ORM功能的时候主要用到的文件有:映射类(*.java)、映射文件(*.hbm.xml)和数据库配置文件(*.properties/*.cfg.xml),它们各自的作用如下:

映射类(*.java):它是描述数据库表的结构,表中的字段在类中被描述成属性,将来就可以实现把表中的记录映射成为该类的对象了。

映射文件(*.hbm.xml):它是指定数据库表和映射类之间的关系,包括映射类和数据库表的对应关系、表字段和类属性类型的对应关系以及表字段和类属性名称的对应关系等。

  数据库配置文件(*.properties/*.cfg.xml):它是指定与数据库连接时需要的连接信息,比如连接哪种数据库、登录数据库的用户名、登录密码以及连接字符串等。当然还可以把映射类的地址映射信息放在这里。

 Hibernate的七种映射关系:

 1、        单向一对一关联映射(one-to-one):

两个对象之间一对的关系,例如:Person(人)-IdCard(身份证)

有两种策略可以实现一对一的关联映射:

*主键关联:即让两个对象具有相同的主键值,以表明它们之间的一一对应的关系;数据库表不会有额外的字段来维护它们之间的关系,仅通过表的主键来关联。如下图:

例子:单向一对一主键关联例子连接

*唯一外键关联:外键关联,本来是用于多对一的配置,但是加上唯一的限制之后(采用<many-to-one>标签来映射,指定多的一端unique为true,这样就限制了多的一端的多重性为一),也可以用来表示一对一关联关系,其实它就是多对一的特殊情况。如下图:

例子:单向一对一唯一外键关联例子连接

注意:因为一对一的主键关联映射扩展性不好,当我们的需要发生改变想要将其变为一对多的时候变无法操作了,所以我们遇到一对一关联的时候经常会采用唯一外键关联来解决问题,而很少使用一对一主键关联。

        2、        单向多对一关联映射(many-to-one):

多对一关联映射原理:在多的一端加入一个外键,指向一的一端,如下图:

关键映射代码——在多的一端加入如下标签映射:

<many-to-one name="group" column="groupid"/>  <many-to-one name="group" column="groupid"/>

 

3、         单向一对多关联映射(one-to-many)

一对多关联映射和多对一关联映射原理是一致的,都是在多的一端加入一个外键,指向一的一端。如下图(学生和班级):

注意:它与多对一的区别是维护的关系不同

*多对一维护的关系是:多指向一的关系,有了此关系,加载多的时候可以将一加载上来

*一对多维护的关系是:一指向多的关系,有了此关系,在加载一的时候可以将多加载上来

关键映射代码——在一的一端加入如下标签映射:

<set name="students">  <key column="classesid"/>  <one-to-many class="com.hibernate.Student"/>
</set>  <set name="students"><key column="classesid"/><one-to-many class="com.hibernate.Student"/></set>

 

缺陷:因为多的一端Student不知道Classes的存在(也就是Student没有维护与Classes的关系)所以在保存Student的时候关系字段classesid是为null的,如果将该关系字段设置为非空,则将无法保存数据,常用解决办法是改用双向关联映射,参见6。

4、         单向多对多映射(many-to-many)

多对多关联映射新增加一张表才完成基本映射,如下图:

关键映射代码——可以在User的一端加入如下标签映射:

<set name="roles" table="t_user_role">  <key column="user_id"/>  <many-to-many class="com.hibernate.Role" column="role_id"/>
</set>  <set name="roles" table="t_user_role"><key column="user_id"/><many-to-many class="com.hibernate.Role" column="role_id"/></set>

 

5、         双向一对一关联映射

对比单向一对一映射,需要在IdCard加入<one-to-one>标签,它不影响,只影响加载。如下图:

双向一对一主键映射关键映射代码——在IdCard端新加入如下标签映射:

<one-to-one name="person"/>  <one-to-one name="person"/>

 

双向一对一唯一外键映射关键映射代码——在IdCard端新加入如下标签映射:

<one-to-one name="person"property-ref="idCard"/>  <one-to-one name="person"property-ref="idCard"/>

 

注意:一对一唯一外键关联双向采用<one-to-one>标签映射,必须指定<one-to-one>标签中的property-ref属性为关系字段的名称

6、         双向一对多关联映射(非常重要)

采用一对多双向关联映射的目的主要是为了主要是为了解决一对多单向关联的缺陷而不是需求驱动的。

一对多双向关联的映射方式:

* 在一的一端的集合上采用<key>标签,在多的一端加入一个外键

* 在多的一端采用<many-to-one>标签

注意:<key>标签和<many-to-one>标签加入的字段保持一直,否则会产生数据混乱

关键映射代码:

在Classes的一端加入如下标签映射:

<set name="students"inverse="true">  <key column="classesid"/>  <one-to-many class="com.hibernate.Student"/>
</set>  <set name="students"inverse="true"><key column="classesid"/><one-to-many class="com.hibernate.Student"/></set>

 

在Student的一端加入如下标签映射:

<many-to-one name="classes" column="classesid"/>  <many-to-one name="classes" column="classesid"/>

 

注释:inverse属性

* inverse属性可以用在一对多和多对多双向关联上,inverse属性默认为false,为false表示本端可以维护关系,如果inverse为true,则本端不能维护关系,会交给另一端维护关系,本端失效。所以一对多关联映射我们通常在多的一端维护关系,让一的一端失效。

* inverse是控制方向上的反转,只影响存储

7、         双向多对多关联映射

双向的目的就是为了两端都能将对方加载上来,和单向多对多的区别就是双向需要在两端都加入标签映射,需要注意的是:

* 生成的中间表名称必须一样

* 生成的中间表中的字段必须一样

Role(角色)端关键映射代码:

<set name="users" table="t_user_role">  <key column="role_id"/>  <many-to-many class="com.hibernate.User" column="user_id"/>
lt;/set>  <set name="users" table="t_user_role"><key column="role_id"/><many-to-many class="com.hibernate.User" column="user_id"/></set>

 

User(用户)端关键映射代码:

<set name="roles" table="t_user_role">  <key column="user_id"/>  <many-to-many class="com. hibernate.Role" column="role_id"/>
lt;/set>  <set name="roles" table="t_user_role"><key column="user_id"/><many-to-many class="com. hibernate.Role" column="role_id"/></set>

总结:对于上面这七种关联映射中,最重要的就是一对多的映射,因为它更贴近我们的现实生活,比如:教室和学生就可以是典型的一对多的关系,而我们开发软件的目的之一就是为了解决一些生活中重复性问题,把那些重复的问题交给计算机帮助我们完成,从而来提高我们的工作效率。一句话:生活离开不开编程,编程更离不开生活。

原文地址:http://blog.csdn.net/smszhuang168/article/details/7761310

转载于:https://www.cnblogs.com/quyongjin/p/3208871.html

对象-关系映射ORM(Object Relational Mapping)(转)相关推荐

  1. 学习笔记之什么是持久化和对象关系映射ORM技术

    ----------------本文转自:http://www.cppblog.com/javenstudio/articles/541.html--------------------- 何谓&qu ...

  2. 对象关系映射(ORM)及代码生成器和插件C#源码(DBFrameworkV4.5.3)

    1. ORM及代码生成器和插件C#源码(DBFrameworkV4.5.3) 一.使用对象关系映射组件Kenly.DBFramework.dll不用编写任何SQL或者存储过程即可实现下列功能: 1.数 ...

  3. 通过java反射实现简单的关于MongoDB的对象关系映射(ORM).

    通过阅读MongoDB  3.2.1的官方文档中关于java 编程发现最新的文档并没有实现对对象到Document的映射,所以自己有了利用反射实现简单的关系映射. 1.定义抽象类:AbstractMo ...

  4. python中通过元类(TYPE)简单实现对象关系映射(ORM)

    ORM是创建一个实例对象,用创建他的类名当做数据表名,用创建他的类属性对应数据表的字段,不需要在自己写复杂的sql语句,而是通过对实例对象的操作时,能让代码自动帮我们整理为对应的sql语句. clas ...

  5. Django中的Object Relational Mapping(ORM)

    ORM 介绍 ORM 概念 对象关系映射(Object Relational Mapping,简称ORM)模式是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用 ...

  6. Java对象关系映射(ORM)

    一.什么是对象关系映射 简单来说,对象关系映射即是将Java中的对象一一对应映射到MySQL(本文基于MySQL)的Table(表)中,通过对对象各个属性赋值来更新数据库. 官方的说,对象关系映射(O ...

  7. 对象关系映射(ORM)介绍理解

    问题背景 假设,让你设计一个框架,把jdbc封装一下?? JDBC操作步骤: 获取数据库连接Connection 创建操作命令对象Statement 执行sql语句(sql中,如果有占位符,在执行sq ...

  8. 对象关系映射(ORM)

      本文主要介绍 对象关系映射(ORM) 是什么,以及它的优缺点. 一.ORM 简介   面向对象是从软件工程基本原则(如耦合.聚合.封装)的基础上发展起来的,而关系数据库则是从数学理论发展而来的,两 ...

  9. 【分享】关于对象关系映射的理解

    对象关系映射(Object Relational Mapping,简称ORM)是一种为了解决面向对象与关系数据库存在的互不匹配的现象的技术. 简单的说,ORM是通过使用描述对象和数据库之间映射的元数据 ...

最新文章

  1. vue-cli3环境变量与分环境打包
  2. 进程间通信 —— 命名管道
  3. 第七周项目三-用多文件组织多个类的程序
  4. 2015 Google code jam Qualification Round A 水
  5. mysql upgrade 失败_`mysql_upgrade`失败,没有给出真正的理由
  6. Statement对象最新解析
  7. ActiveMQ学习笔记之异常
  8. 4g网络什么时候淘汰_4G升级5G,4G网络不会被淘汰,与5G继续共存
  9. .Net Framework3.5 的 NetFx3.cab 资源
  10. python写监控脚本_python写个进程监控的脚本
  11. python四分位数_Python:获取四分位数的数组索引
  12. CF#446 Gluttony(思维题)
  13. 修改linux域名解析失败,kali 更新域名解析失败问题解决办法
  14. xposed框架的检测和反制
  15. 2016年蓝桥杯C++ A组初赛试题
  16. 号码认证平台有哪些?号码认证平台费用?
  17. 听音乐用什么蓝牙耳机好?音质好的tws蓝牙耳机推荐
  18. Python使用随机森林预测泰坦尼克号生存
  19. 柯基数据携手亚马逊云科技打造一站式知识图谱平台案例
  20. vue3中使用swiper7轮播图插件

热门文章

  1. 开滦二中2021高考成绩查询,2021唐山中考录取分数线查询
  2. 根目录_ubuntu 18.04 server版根目录只有4G?
  3. 将图片序列帧合成mp4_超级详细!如何将B站缓存m4s文件无损转换为mp4格式
  4. java实现连拍_Camera2连拍相关问题
  5. kali无法共享本机文件_MySQL服务端读取客户端文件漏洞的复现
  6. LettCode50. Pow(x, n)
  7. SpringBoot整合Shiro实现登录认证授权操作
  8. Redis底部的几种存储结构(sds、dict、ziplist、intset、skiplist)
  9. Python风格总结:日期操作
  10. C++ delete删除动态分配的内存