【Hibernate学习】 ——ORM(一)
Hibernate是一种能实现ORM的框架。
ORM即Object
Relational Mapping。对象关系映射。也就是将关系数据库中表的数据映射成为对象。也就是说将表与表之间的操作映射成对象与对象之间的操作,通过实体类来达到操作表的目的。总之就是把对数据库的操作转化为对对象的操作,从而更体现了面向对象的思想。
一对一关联映射策略包含主键关联和唯一外键关联。
单向一对一
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGl1dGVuZ3RlbmcxMzA=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
主键关联
让两个对象有同样的主键值,表名它们之间的一对一关系。数据库没有额外的字段来维护它们之间的关系,只通过表的主键来关联。例如以下图:通过两个表中id来维护关系。没有额外的字段或者表去维护其之间的关系。
从图中可看出,既然是单向关联,那么Person能够持有IdCard对象。而IdCard对象不知道Person的存在。故因此由Person端来维护关系。
Person.hbm.xml关系代码
<class name="com.bjpowernode.hibernate.Person" table="t_person">
<id name="id">
<generator class="foreign">
<!--property仅仅关联对象-->
<param name="property">idCard</param>
</generator>
</id>
<property name="name">
<!--
one-to-one指示hibernate怎样载入其关联对象。默认依据主键载入
也就是拿到关系字段值,依据对端的主键来载入关联对象 constrained="true"表示,当前主键(person的主键)还是一个外键
參照了对端的主键(IdCard的主键)。也就是会生成外键约束语句
-->
<one-to-one name="idCard" constrained="true">
</class>
IdCard.hbm.xml代码
<class name="com.bjpowernode.hibernate.Person" table="t_idCard">
<id name="id">
<generator class="native">
</id>
<property name="cardNo"/> </class>
唯一外键关联
外键关联被拿来是用于多对一的配置。可是假设加上唯一的限制之后。也能够用来表示一对一的关联关系。因此唯一外键关联是多对一的一种特殊情况。是通过<many-to-one>映射的。
表关系:
通过<many-to-one>映射。会在person端生成idCard字段。通过idCard字段来维护关系。
unique表示是唯一外键关联。故还是通过person端来维护关系,所以和主键关联对照仅仅须要更改person关系中的标签为<many-to-one>,不须要更改idCard关系代码。
主要改变的是Person类的映射:
<class name="com.bjpowernode.hibernat.Person" table="t_person">
<id name="id">
<generator class="native"/>
</id>
<property name="name"/>
<!--设置idCard为外键,唯一标识为true-->
<many-to-one name="idCard" unique="true"/>
</class>
小结:通过表关系能够看出来,主键关联是通过person表中的id来维护关系,没有多余的字段,相当于id既当主键又当外键。改动数据非常难;而唯一外键关联是增加第三个字段来维护关系。可扩展性显然比主键关联好。
——————————————————————————————————————————————
双向一对一
主键关联
上面是单向的,那么设置成双向的。也就是IdCard也想得到与之相应的Person对象。那么IdCard就须要增加person属性。例如以下:
Person关系映射同主键关联映射。
idCard关系映射:
<class name="com.bjpowernode.hibernate.Person" table="t_idCard">
<id name="id">
<generator class="native">
</id>
<property name="cardNo"/>
<one-to-one name="person"/>
</class>
比起单向关联外。双向关联的关系在IdCard端增加<one-to-one>标签。idCard也持有Person的引用。<one-to-one>标签不影响存储,仅仅影响载入,故单向关联和双联关联的表结构是一样的。
唯一外键关联
表关系:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGl1dGVuZ3RlbmcxMzA=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">
同单向关联的关系一样。生成的表结构也一样。
person关系代码同单向。
idCard关系代码:
<class name="com.bjpowernode.hibernate.Person" table="t_idCard">
<id name="id">
<generator class="native">
</id>
<property name="cardNo"/>
<!--体现双向关联-->
<one-to-one name="person" property-ref="idCard"/>
</class>
相同是在idCard端增加关联<one-to-one>标签。
须要加如property-ref="idCard",为关系字段的名称。
由于idCard不为主键,所以要增加此属性。
———————————————————————————————————————————————
综上。单向和双向的差别就是对关系的持有,在idCard端加入<one-to-one>标签,此标签不影响存储,仅仅影响载入。所以上面四种关系能够看成是两种关系,主键关联和唯一外键关联。而主键关联和唯一外键关联的差别是主外键的关系。前者是Person中id是主键又是外键。后者是加入一个关系字段作为外键。可是都是Person来维护关系。
通过总结,对照之后特别清晰,简单易懂。下篇博客继续分析。
【Hibernate学习】 ——ORM(一)的更多相关文章
- 学习ORM框架—hibernate(三):跟踪持久化对象状态,掌握对象持久化
准备工作 在上篇博客中学习ORM框架—hibernate(一):初识hibernate,通过简单的实例说明O和R的映射过程.本篇博客将要介绍hibernate中持久化对象的状态,并使用hibernat ...
- Hibernate学习笔记(一)
2016/4/18 19:58:58 Hibernate学习笔记(一) 1.Hibernate框架的概述: 就是一个持久层的ORM框架. ORM:对象关系映射.将Java中实体对象与关系型数据库中表建 ...
- Hibernate学习总汇
Hibernate的基础知识 什么是框架? 什么是Hibernate框架? |--1.应用在javaee三层结构中的dao层 |--2.在dao层里面做对数据库进行crud操作,使用hibernate ...
- Hibernate学习笔记一 使用idea开发工具搭建框架
1.导包,包下载地址:http://hibernate.org/orm/downloads/ 2.创建数据库,准备表,实体.示例: CREATE TABLE `cst_customer` ( `cus ...
- hibernate学习(1)
对象的持久化 狭义的理解,“持久化”仅仅指把对象永久保存到数据库中 广义的理解,“持久化”包括和数据库相关的各种操作 -保存:把对象永久保存到数据库中 -更新:更新数据库中对象的状态 -删除:从数据库 ...
- hibernate学习-HibernateDemo
上篇文章我们讲述了eclipse安装hibernate插件的过程,这篇文章我们来做第一个HibernateDemo. 1).hibernate的jar开发包的下载,官网下载地址:http://hibe ...
- Hibernate学习之——搭建log4j日志环境
昨天讲了Hibernate开发环境的搭建以及实现一个Hibernate的基础示例,但是你会发现运行输出只有sql语句,很多输出信息都看不见.这是因为用到的是slf4j-nop-1.6.1.jar的实现 ...
- Hibernate学习笔记(二)
2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...
- Hibernate 学习笔记一
Hibernate 学习笔记一 今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子.期间碰 ...
- Hibernate学习总结
首先声明这是个坑爹的框架 属于ssh经典框架中的持久层框架,说白了就是管理数据库的. 下载地址:http://hibernate.org/orm/ 这里写了版本5.2,下载下来的基本不怎么会用,因为文 ...
随机推荐
- 迅为嵌入式开发板iTOP-6818开发板八核Cortex-A53架构,满足各种产品需求
性价比更高 内存:1G(可选2G);存储:16G;4418:四核 Cortex-A9;6818:八核Cortex-A53. 功能更强 板载4G(全网通),GPS,WIFI,千兆以太网,重力加速度计等, ...
- 使用Gson解析Json数组遇到的泛型类型擦除问题解决方法
谷歌Gson转换Json串有如下方法: public Object fromJson(String json, Type typeOfT);1可以使用它进行数组解析.如下,使用此方法解析Json串为类 ...
- nexus 搭建 maven 私服
nexus 搭建 maven 私服 本机环境 Win 8 JDK 7 Maven 3.2 Nexus 2.11 版本选择 http://www.sonatype.org/nexus/archivedn ...
- 初始化react项目
react脚手架 npm install -g create-react-app 国内npm一般下载比较慢或者是常出现下载失败的情况,我们可以指定下载的仓库: npm install -g creat ...
- sqlserver 创建索引 物化 视图
索引视图: create view Test WITH SCHEMABINDING as select Id, Name from [dbo].[InterfaceCallSetting]creat ...
- C# WebService 的缓存机制
C# WebService 的缓存机制 [转]WebService的缓存机制 2008年02月19日 星期二 11:22 WebService的缓存分为两种,一种是简单的输出缓存,一种是强大的数据 ...
- 动态 SQL(1)
使用动态 SQL 完成多条件查询 动态 SQL 是 MyBatis 的一个强大的特性.在使用 JDBC 操作数据时,如果查询条件特别多,将条件串联成 SQL 字符串是一件痛苦的事情,通常的解决方法是写 ...
- UVa 11998 破碎的键盘(数组实现链表)
题意: 输入一行字符,其中包含'[' 和 ‘]’, 意思为键盘上的home 和 end 键, 然后模拟字符在键盘上输入. 输入一行最终的结果 分析: 用数组模拟一个链表, 在链表的头尾插入字母然后输出 ...
- Django——配置服务器上线
使用UWSGI和NGINX配置项目上线 首先你得有一个拿得出手的项目 其次,购买了域名,也备案成功了 将settings.py中的DEBUG设置为False 配置Uwsgi 在项目(哪里都可以)中创建 ...
- 【扫描线】HDU 5124 lines
http://acm.hdu.edu.cn/showproblem.php?pid=5124 [题意] 在数轴x上,每次操作都覆盖一个区间的所有点,问被覆盖次数最多的点是覆盖了多少次 [思路] 最简单 ...