Hibernate之1-N关联映射
须要从业务的角度来说明。比如,Employee 和 Department 之间就是 n-1 的关联关系,Order 和 Customer 之间也是 n-1 的关联关系。
1). 关联关系是有方向的:
2). 怎样在类中来建立关联关系呢 ?
2. 单向 n-1 关联关系
1). 域对象中,在 Order 中声明一个 Customer 类型的成员变量,并提供 setter、getter
public class Order {
private Integer orderId;
private String orderName;
private Customer customer;
//...
}
2). 数据表:
3). 怎样进行映射:通过 many-to-one 来映射
①. 注意:须要映射在 ORDERS 数据表中的外键列!
<many-to-one name="customer"
column="CUSTOMER_ID"
class="Customer"></many-to-one>
4). API 操作时
①. save 时,若先保存 Order, 在保存 Customer,则会多出 UPDATE 语句;若先保存 Customer,再保存 Order,则仅仅有 INSERT. 建议先保存 1 的一端的对象
②. get 时,
◆默认情况下,关联对象採取 懒载入 策略。即在获取 Order 时,若不使用关联的 Customer 的属性,
◆有懒载入就可能会发生懒载入异常:org.hibernate.LazyInitializationException。
载入异常。
③. update 时,
◆若对象本身是一个持久化对象,则在 flush Session 时,会级联更新其关联的对象的属性。
◆若对象是游离对象,则不会更新关联对象的属性。但可以通过设置 cascade 属性来使其可以进行更新
④. delete 时,
◆删除对象,仅仅须要 ID 属性
◆防止发生外键约束异常
3. 单向 1-n 关联关系
1). 域对象:添加集合属性
public class Customer {
private Integer customerId;
private String customerName;
//訪问 n 的一端的集合属性
private Set<Order> orders = new HashSet<>();
//....
}
注意:
①. 当 Session 从数据库中载入 Java 集合时, 创建的是 Hibernate 内置集合类的实例,
因此在持久化类中定义集合属性时必须把属性声明为 Java 接口类型
②. 在定义集合属性时, 通常把它初始化为集合实现类的一个实例.
避免应用程序訪问取值为 null 的集合的方法抛出 NullPointerException
2).关系数据模型
3). 怎样进行映射,在Customer.hbm.xml中通过 set 元素
<set name="orders" table="ORDERS"
order-by="ORDER_NAME ASC">
<key column="CUSTOMER_ID"></key>
<one-to-many class="Order"/>
</set>
4). API 详细操作:
①. save 时:由于由 1 的一端来维护关联关系,所以一定会多出 UPDATE 语句!
②. update 时:
◆若把集合对象 clear,默认情况下是把多的一端的外键置空
③. delete 时:能够删除 1 的一端,可是把多的一端的外键置空
5). set 的 order-by 属性:能够指定在查询集合时,按集合元素相应的数据表的列进行排序!
<set name="orders" table="ORDERS"
order-by="ORDER_NAME ASC">
<key column="CUSTOMER_ID"></key>
<one-to-many class="Order"/>
</set>
----------------------------------------------------双向关联映射-----------------------------------------------------
4. 双向 1-n 关联关系
1). 怎样进行映射(以下是Customer表,注意两者之间的相应关系)
2). set 元素的 inverse 属性能够指定由哪一方来维护关联关系,
◆ 比方说在Customer表中:
<set name="orders" table="ORDERS"
order-by="ORDER_NAME ASC" inverse="true">
<key column="CUSTOMER_ID"></key>
<one-to-many class="Order"/>
</set>
Hibernate之1-N关联映射的更多相关文章
- Hibernate 、多表关联映射-组件关联映射(component)
组件关联映射可以将一些简小的数据与主题放在一个表中,例如firstName 和LastName这两个结合在一起可以组成一个名字,但是再分别将这两个再建一个表就不太合适了,这个时候可以用到组件关联映射: ...
- Hibernate 、多表关联映射 - 一对一关系映射(one- to-one)
hibernate.cfg.xml: <hibernate-configuration> <session-factory name="sessionFactory&quo ...
- hibernate的多对多关联映射
在我们实际项目中,多对多的情况也时长存在,比如最常见的就是系统管理的五张表,如下面的一个结构: 在本文学习hibernate多对多关联映射的实验中我简单的写几个字段,达到学习目的即可. 1.多对多的关 ...
- Hibernate 性能优化一对一关联映射
概述: hibernate提供了两种映射一对一关联的方式:按照外键映射和按照主键映射. 下面以员工账号和员工档案为例 ,介绍两种映射方式,并使用这两种映射方式分别完成以下持久化操作: (1)保存员工档 ...
- Hibernate 、多表关联映射-多对一关系(many-to-one)
Hibernate.cfg.xml: <session-factory name="sessionFactory"> <property name="h ...
- 8.Hibernate的多对多关联映射
1.创建如下数据库脚本 --1.1 项目表 create table PROJECT ( proid ) not null, proname ) ) ; --1.2 项目表主键 alter table ...
- Hibernate一对多双向关联映射
建立多对一的单向关联关系 Emp.java private Integer empNo //员工编号 private String empName / ...
- java:Hibernate框架2(关联映射(多对一,一对多,一对多双向,一对一主键,一对一唯一外键,多对多双向))
hibernate.cfg.xml: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE h ...
- Hibernate 、多表关联映射 - 多对多关系映射(many-to-many)
hibernate.cfg.xml: <hibernate-configuration> <session-factory name="sessionFactory&quo ...
- 15.Hibernate一对多双向关联映射+分页
1.创建如下数据库脚本 --创建用户信息表 --编号,用户名,密码,年龄,性别,昵称,手机,地址,管理员,图像地址 create table users ( id ) primary key, use ...
随机推荐
- 用c#开发微信(10) JSSDK 基本用法 分享接口“发送到朋友”
微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包.通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照.选图.语音.位置等手机系统的能力,同时可以直接使用微信分享. ...
- iOS - 单例传值 (一)
点击打开链接 iOS - 单例传值 (二) 单例只会对某个类实例化一次/单例类,对单例这个类实例化一次有且仅有一个对象 你单例初始化,只能初始化一次,然后你指向的对象,其实都是指向一个内存地址, ...
- 基于visual Studio2013解决面试题之1307二分查找
题目
- 基于visual Studio2013解决C语言竞赛题之1038数字验证
题目 解决代码及点评 /********************************************************************** ...
- javascript 浏览器兼容性写法
var event = window.event || arguments.callee.caller.arguments[0]; // 获取event对象 event = event.srcElem ...
- sharepoint 2013 根据网站模版创建网站,并赋值网站权限 create a site by custom site template
通过程序,根据网站模版,创建新的网站 private void CreateSiteBySiteTemplate() { SPSecurity.RunWithElevatedPrivileges(de ...
- How to search a table in a store proc and open the store proc
1. select*fromdba_dependencieswherereferenced_name='CNTL_ISSUE'andTYPE='PROCEDURE' 2. selecttextfrom ...
- 《火球——UML大战需求分析》(第2章 耗尽脑汁的需求分析工作)——2.1 需求分析面面观
说明: <火球——UML大战需求分析>是我撰写的一本关于需求分析及UML方面的书,我将会在CSDN上为大家分享前面几章的内容,总字数在几万以上,图片有数十张.欢迎你按文章的序号顺序阅读,谢 ...
- TCP/IP协议的编写《转载》
基于HHARM9-EDU的TCP/IP(UDP)协议的实现 原文网址:http://blog.csdn.net/lhj0503/article/details/3323788 摘 要:嵌入式技术的发展 ...
- Window7下安装openssl完整版(亲测实现)
安装环境: 操作系统:window7(64位) C++编译器:VS2010 -------------------------------------------------------------- ...