转自:https://blog.csdn.net/fengxuezhiye/article/details/7369786?utm_source=blogxgwz9

Hibernate的关联映射关系有:
多对一 ---- many-to-one
一对多 ---- one-to-many
一对一 ---- one-to-one
多对多 ---- many-to-many

比较常用的是多对一和一对一关联映射

多对一关联映射:
场景:用户和组;从用户角度来看,多个用户属于一个组(多对一关联)
使用hibernate开发的思路:先建立对象模型,把实体抽取出来。目前两个实体:用户和组两个实体,多个用户
属于一个组,所有用户实体中应该有一个持有组的引用

对象模型图

关系模型:

关系映射的本质:

将关联关系映射到数据库,所谓的关联关系就是对象模型在内存中的一个或多个引用

User实体类:

  1. public class User {
  2. private int id;
  3. private String name;
  4. private Group group;
  5. public Group getGroup() {
  6. return group;
  7. }
  8. public void setGroup(Group group) {
  9. this.group = group;
  10. }
  11. public int getId() {
  12. return id;
  13. }
  14. public void setId(int id) {
  15. this.id = id;
  16. }
  17. public String getName() {
  18. return name;
  19. }
  20. public void setName(String name) {
  21. this.name = name;
  22. }
  23. }

Group实体类

  1. public class Group {
  2. private int id;
  3. private String name;
  4. public int getId() {
  5. return id;
  6. }
  7. public void setId(int id) {
  8. this.id = id;
  9. }
  10. public String getName() {
  11. return name;
  12. }
  13. public void setName(String name) {
  14. this.name = name;
  15. }
  16. }

Group实体类映射文件:

  1. <hibernate-mapping>
  2. <class name="com.wjt276.hibernate.Group" table="t_group">
  3. <id name="id" column="id">
  4. <generator class="native"/>
  5. </id>
  6. <property name="name"/>
  7. </class>
  8. </hibernate-mapping>

User实体类映射文件:

  1. <hibernate-mapping>
  2. <class name="com.wjt276.hibernate.User" table="t_user">
  3. <id name="id" column="id">
  4. <generator class="native"/>
  5. </id>
  6. <property name="name"/>
  7. <!--<many-to-one> 关联映射 多对一的关系
  8. name:是维护的属性(User.group),这样表示在多的一端表里加入一个字段名称为group,
  9. 但group与SQL中的关键字重复,所以需要重新命名字段(column="groupid").
  10. 这样这个字段(groupid)会作为外键参照数据库中group表(t_group也叫一的一端),也就是就在多的一
  11. 端加入一个外键指向一的一端。
  12. -->
  13. <many-to-one name="group" column="groupid"/>
  14. </class>
  15. </hibernate-mapping>


<many-to-one>标签

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

name是维护的属性(User.group),这样表示在多的一端表里加入一个字段名称为group,但group与SQL中的关键字重复,所以需要重新命名字段(column="groupid"),这样这个字段(groupid)会被作为外键参照数据库中的group表,也就是在多的一端加入一个外键指向一的一端。

多对一的存储(先存储group,再保存user)

  1. session = HibernateUtils.getSession();
  2. tx = session.beginTransaction();
  3. Group group = new Group();
  4. group.setName("wjt276");
  5. session.save(group); //存储Group对象。
  6. User user1 = new User();
  7. user1.setName("菜10");
  8. user1.setGroup(group);//设置用户所属的组
  9. User user2 = new User();
  10. user2.setName("容祖儿");
  11. user2.setGroup(group);//设置用户所属的组
  12. //开始存储
  13. session.save(user1);//存储用户
  14. session.save(user2);
  15. tx.commit();//提交事务

注意:如果上面的session.save(group)不执行,则存储不成功。会抛出TransientObjectException异常。因为Group为Transient状,Object的id没有分配值

persistent状态的对象不能引用Transient状态的对象

以上的代码操作,必须首先保存group对象,再保存user对象。我们可以利用cascade(级联)方式,不需要先保存group对象,而是直接保存user对象,这样就可以在存储user之前先把group存储了, 
利用cascade属性是解决TransientObjectException的一种手段

cascade(级联)
  级联的意思是指两个对象之间的操作联运关系,对一个对象执行了操作之后,对其指定的级联对象也需要执行相同的操作,取值:all,none,save_update,delete
  1.all:代码在所有情况下都执行级联操作
  2.none:在所有情况下都不执行级联操作
  3.save-update:在保存和更新的情况下执行级联操作
  4.delete:在删除的时候执行级联操作

  1. <many-to-one name="groupo" column="groupid" cascade="save_update" />

多对一 加载数据

  1. session = HibernateUtils.getSession();
  2. tx = session.beginTransaction();
  3. User user = (User)session.load(User.class, 3);
  4. System.out.println("user.name=" + user.getName());
  5. System.out.println("user.group.name=" + user.getGroup().getName());
  6. //提交事务
  7. tx.commit();

因为采用了<many-to-one>这个标签,这个标签会在多的一端(User)加一个外键,指向一的一端(Group),也就是它维护了从多到一的这种关系,多指向一的关系。当你加载多一端的数据时,它能把一的这一端的数据加载上来。当加载User对象后hibernate会根据User对象中的groupid再来加载Group信息给User对象中的group属性

Hibernate关联映射(多对一 --- many-to-one)的更多相关文章

  1. (转)Hibernate关联映射——一对多(多对一)

    http://blog.csdn.net/yerenyuan_pku/article/details/70152173 Hibernate关联映射——一对多(多对一) 我们以客户(Customer)与 ...

  2. Hibernate关联映射(一对多/多对多)

    版权声明:翀版 https://blog.csdn.net/biggerchong/article/details/843401053.  Hibernate关联映射上接Hibernate持久化类:h ...

  3. Hibernate关联映射关系

    Hibernate关联映射关系 一.双向一对多关联映射关系:当类与类之间建立了关联,就可以方便的从一个对象导航到另一个或另一组与它关联的对象(一对多双向关联和多对一双向关联是完全一样的) 1.1创建实 ...

  4. 第六章 Hibernate关联映射

    第六章 hibernate关联映射一.本章知识点分为2部分:1.关联关系:单向多对一关联关系,双向一对多关联关系(含一对多关联关系),多对多关联关系2.延迟加载:类级别加载策略,一对多加载策略,多对一 ...

  5. 【学习笔记】Hibernate关联映射(Y2-1-6)

    Hibernate关联映射 关联映射就是将关联关系映射到数据库里,在对象模型中就是一个或多个引用. 1.单向多对一关联 准备数据库 部门表和员工表 其中部门表有两列 部门编号和名称 员工表有三列 员工 ...

  6. 第三章Hibernate关联映射

    第三章Hibernate关联映射 一.关联关系 类与类之间最普通的关系就是关联关系,而且关联是有方向的. 以部门和员工为列,一个部门下有多个员工,而一个员工只能属于一个部门,从员工到部门就是多对一关联 ...

  7. (转)Hibernate关联映射——对象的三种关系

    http://blog.csdn.net/yerenyuan_pku/article/details/70148618 Hibernate关联映射——对象的三种关系 Hibernate框架基于ORM设 ...

  8. Oracle primary,unique,foreign 区别,Hibernate 关联映射

    Oracle primary,unique,foreign 区别 转:http://www.cnblogs.com/henw/archive/2012/08/15/2639510.html NOT N ...

  9. Hibernate关联映射(单项多对一和一对多、双向一对多)

    最近总是接触着新的知识点来扩展自己的知识面:不停的让自己在原地接触天空的感觉真的很美好!!!革命没有成功,程序员的我们怎么能不努力呢...... 一.用员工和部门来剖析关联映射的原理. 1)从这张截图 ...

随机推荐

  1. 解决Genymotion运行Android 5.0一直卡在开机界面

    在一些机器,启动genymotion 的android5.0版模拟器时,会卡在启动界面,一直启动不了. 这是因为要求的开启虚拟选项没有打开,在第一次启动时,会有提示,但可能大家没有注意(我也没注意到, ...

  2. 金明的预算方案(codevs 1155)

    题目描述 Description 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间金明自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只 ...

  3. P1003 铺地毯(noip 2011)

    洛谷——P1003 铺地毯 题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯 ...

  4. Linux内存管理-内核的shmall和shmmax参数(性能调优)(转)

    内核的shmall和shmmax参数 SHMMAX=配置了最大的内存segment的大小:这个设置的比SGA_MAX_SIZE大比较好. SHMMIN=最小的内存segment的大小 SHMMNI=整 ...

  5. MySql基本数据类型(转)

    说明:通俗的理解:1字节的8位,即1byte=8bit,而这个1byte叫做长度范围,范围的算法是使用bit去求,比如8bit的长度范围是2的8次方,但是在数据库中的类型上是有区分有符号和无符号的,默 ...

  6. Spring的AOP AspectJ切入点语法详解(转)

    一.Spring AOP支持的AspectJ切入点指示符 切入点指示符用来指示切入点表达式目的,在Spring AOP中目前只有执行方法这一个连接点,Spring AOP支持的AspectJ切入点指示 ...

  7. [转]三层架构与MVC之间的区别

    我们平时总是将三层架构与MVC混为一谈,殊不知它俩并不是一个概念.下面我来为大家揭晓我所知道的一些真相. 首先,它俩根本不是一个概念. 三层架构是一个分层式的软件体系架构设计,它可适用于任何一个项目. ...

  8. CentOS 6.x ELK(Elasticsearch+Logstash+Kibana)

    CentOS 6.x ELK(Elasticsearch+Logstash+Kibana) 前言 Elasticsearch + Logstash + Kibana(ELK)是一套开源的日志管理方案, ...

  9. win8系统 重装系统如何删除EFI分区

    在PE下(一般重装系统就是在PE下),依次输入如下命令(注意虽然显示的是中文名"磁盘0",但是还是用英文disk 0) list disk select disk 0 clean

  10. Android - 渠道号(vender)

    渠道号(vender) 本文地址: http://blog.csdn.net/caroline_wendy Android的apk公布,须要统计各个渠道(vendor)的激活数.就能够使用vendor ...