一对一关联

Hibernate提供了两种映射一对一关联关系的方式:按照外键映射和按照主键映射。下面以员工账号和员工档案表为例,介绍这两种映射方式,并使用这两种映射方式分别完成以下持久化操作:

(1)保存员工档案的同时分配给员工一个账号。

(2)加载员工档案的同时加载账号信息。

按照外键映射:

关系图:

①创建实体类:Resume、Users 并封装属性

 1 public class Resume {
 2     //档案id
 3     private Integer resid;
 4     //档案名称
 5     private String resname;
 6     //档案编号
 7     private String rescardno;
 8     //员工对象
 9     private Users users;
10 }

 1 public class Users {
 2    //员工id
 3     private Integer userid;
 4     //员工姓名
 5     private String username;
 6     //员工密码
 7     private String userpass;
 8     //档案对象
 9     private Resume resume;
 10  }

② 配置小配置 Users.hbm.xml

注:property-ref="users" 表明Resume的users属性建立了从Users对象到Resume对象的关联

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC
 3     "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 4     "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 5 <hibernate-mapping package="cn.happy.entity">
 6    <class name="Users" table="USERS1">
 7      <id name="userid" column="USERID" >
 8          <generator class="native"></generator>
 9      </id>
10      <property name="username" column="USERNAME" type="string"></property>
11      <property name="userpass" column="USERPASS" type="string"></property>
12     <!-- 配置一对一外键关系的关联 -->
13      <one-to-one name="resume" class="Resume" property-ref="users"></one-to-one>
14    </class>
15 </hibernate-mapping>

Resume.hbm.xml

注:因为Resume为外键表 植入<many-to-one>元素 并设置属性unique=“true” 确保用户档案的列只能是唯一的, 一个档案对应一个用户编号

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 3                             "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 4 <hibernate-mapping package="cn.happy.entity">
 5  <class name="Resume" table="RESUME1">
 6   <id column="RESID" name="resid">
 7    <generator class="native"></generator>
 8   </id>
 9   <property column="RESNAME" name="resname" type="string"/>
10   <property column="RESCARDNO" name="rescardno" type="string"/>
11   <!--主的一方  -->
12
13   <!-- 在用户档案指定的列只能是唯一的   一个档案只能对应一个用户编号-->
14   <many-to-one  name="users" cascade="all" class="Users" column="RESCARDID" unique="true"/>
15  </class>
16 </hibernate-mapping>

③ 大配置进行关联小配置

1 <!-- 关联小配置 -->
2 <mapping resource="cn/happy/entity/Users.hbm.xml" />
3 <mapping resource="cn/happy/entity/Resume.hbm.xml" />

测试类:

 1      /*
 2      * 添加
 3      */
 4     @Test
 5     public void addTest(){
 6         //创建用户对象
 7         Users u=new Users();
 8         u.setUsername("张三1");
 9         u.setUserpass("003");
10         //创建档案对象
11         Resume r=new Resume();
12         r.setResname("大学文凭1");
13         r.setRescardno("003");
14         //关联
15         u.setResume(r);
16         r.setUsers(u);
17         //保存档案,员工自动save
18         session.save(r);
19         System.out.println("save ok!!!");
20
21     }

按照主键映射:

关系图如下:

实体类同上

其次就是小配置的更改。Resume为主键表,Users的Userid既是主键又是外键 因此植入元素generator的类型为foreign主键

<one-to-one>植入属性constrained 用来约束 在底层数据表中植入外键

Users.hbm.xml配置文件如下:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC
 3     "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 4     "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 5 <hibernate-mapping package="cn.happy.pk">
 6    <class name="Users2" table="USERS2">
 7      <id name="userid" column="USERID" >
 8          <generator class="foreign">
 9             <param name="property">resume2</param>
10          </generator>
11      </id>
12      <property name="username" column="USERNAME" type="string"></property>
13      <property name="userpass" column="USERPASS" type="string"></property>
14      <!-- constrained:用来约束 在底层USERS2数据表中,植入外键-->
15      <one-to-one name="resume2" class="Resume2" constrained="true"></one-to-one>
16    </class>
17 </hibernate-mapping>

Resume.hbm.xml配置如下:

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 3                             "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
 4 <hibernate-mapping package="cn.happy.pk">
 5  <class name="Resume2" table="RESUME2">
 6   <id column="RESID" name="resid">
 7      <generator class="sequence">
 8        <param name="sequence">SEQ_NUM</param>
 9      </generator>
10   </id>
11   <property column="RESNAME" name="resname" type="string"/>
12   <property column="RESCARDNO" name="rescardno" type="string"/>
13   <!--主的一方  -->
14   <one-to-one  name="users2" cascade="all" class="Users2" />
15  </class>
16 </hibernate-mapping>

转载于:https://www.cnblogs.com/Zhangmin123/p/5855524.html

Hibernate一对一关联映射配置相关推荐

  1. Spring Data JPA-单向一对一关联映射

    Spring Data JPA-单向一对一关联映射 假如有一张客户表和一张银行账户表,如果想在客户表中关联该客户的银行账户信息,那么这就是一个单向一对一的映射关系. 配置映射关系 在客户domain中 ...

  2. (转)MyBatis框架的学习(五)——一对一关联映射和一对多关联映射

    http://blog.csdn.net/yerenyuan_pku/article/details/71894172 在实际开发中我们不可能只是对单表进行操作,必然要操作多表,本文就来讲解多表操作中 ...

  3. Spring Data JPA-双向一对一关联映射

    Spring Data JPA-双向一对一关联映射 如果一个男孩和一个女孩相爱,那么她们的心里只能装着对方一个人,不能脚踏好几只船-- 通过上面描述,我们明白这是一个双向的关联关系,而且都是一对一.这 ...

  4. 8 Hibernate:关联映射(Associations)

    Hibernate 关联映射(Associations)分为: 8.1 Hibernate:一对一关联映射    8.1.1 Hibernate:一对一单向关联(unidirectional)     ...

  5. Java程序员从笨鸟到菜鸟之(五十八)细谈Hibernate(九)hibernate一对一关系映射...

    一对一关系映射即为关系双方都含有对方一个引用,其实在生活中一对一关系也很常见,比如人和×××,学生和学号等,都是一对一的关系映射,一对一映射分为单向的和双向的,没种关系映射又可以分为主键关联映射,唯一 ...

  6. 初识Hibernate之关联映射(一)

    上篇文章我们对持久化对象进行的学习,了解了它的三种不同的状态并通过它完成对数据库的映射操作.但这都是基于单张表的操作,如果两张或者两张以上的表之间存在某种关联,我们又该如何利用持久化对象进行操作呢?本 ...

  7. Hibernate的关联映射--一对多、

    这是我 1 单向一对多: 实体类:(课程类)Grade与(学生类)Student的一对多关系 学生类: public class Student implements java.io.Serializ ...

  8. chapter6 Hibernate的关联映射

    回顾 ·          下面这个异常是怎么回事?该怎么解决? org.hibernate.MappingException: Unknownentity: com.aptech.jb.entity ...

  9. Hibernate 一对一关联查询

    版权声明:本文为博主原创文章,如需转载请标注转载地址. 博客地址:http://www.cnblogs.com/caoyc/p/5602418.html  一对一关联,可以分为两种.一种是基于外键的关 ...

最新文章

  1. 哪怕你不认可,我还是要为R语言正名
  2. leetcode算法题--叶值的最小代价生成树
  3. 从清明节到儿童节,打造一个童话城市
  4. MySQL关联left join 条件on与where不同
  5. mysql 删除用户变量_MySql安装与MySQL添加用户、删除用户与授权
  6. python基础:python循环、三元运算、字典、文件操作
  7. clickhouse 获取几天前的日期
  8. JAVA定义一个鲜花类_Java作业 题目:16版.情人节送玫瑰花
  9. 决策树剪枝算法(二)
  10. invest模型_ARK Invest最新报告 :AI训练成本下降了100倍,但训练最先进AI模型的成本惊人...
  11. android控件缩放后居中,三大布局的基本摆放属性总结,以及imageVIew图片摆放的缩放问题...
  12. AVI文件在opencore框架下的解析
  13. 解决wps公式编辑器上移情况
  14. 天下大事必作于细,天下难事必作于易
  15. openFrameworks实现的简单捕鱼游戏
  16. iOS 怎么查app的下载量
  17. MCDF-lab4中部分代码理解
  18. 思科网络设备安装与调试——帧中继云配置
  19. 06-手机登录token生成容联云短信验证用户认证和网关整合(网关做统一权限认证)
  20. Materials Studio建模——异质结的建立(2)

热门文章

  1. nginx配置文件基本配置
  2. kettle分批处理大表数据_kettle-批量同步表数据
  3. 如何在安装程序中判断操作系统是否是64位 inno
  4. node--CommonJS
  5. Handler研究2-AsyncTask,AsyncQueryHandler分析
  6. [经典算法] 八枚硬币
  7. ubuntu下安装wine
  8. matplotlib安装错误依赖问题解决
  9. 解决PLSQL 查询后显示中文为问号(???)问题
  10. Android加载大图片OOM异常解决