实体类关系

一对一

一对多

多对一

多对多

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

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

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

1.按照外键映射

步骤一:创建实体类Users1和Resume1

Users1创建如下:

public class Users1 {

private Integer userid;

private String username;

private String userpass;

private Resume1 resume1;

}

Resume1创建如下:

public class Resume1 {

private Integer resid;

private String resname;

private String rescardno;

private Users1 users1;

}

步骤二:配置文件Users1.hbm.xml和Resume1.hbm.xml

Users1.hbm.xml配置如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="cn.happy.onetoone_fk">

<class name="Users1" table="USERS1">

<id name="userid" column="USERID" >

<generator class="native"></generator>

</id>

<property name="username" column="USERNAME" type="string"></property>

<property name="userpass" column="USERPASS" type="string"></property>

<one-to-one name="resume1" class="Resume1" property-ref="users1"></one-to-one>

</class>

</hibernate-mapping>

Resume1.hbm.xml配置如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="cn.happy.onetoone_fk">

<class name="Resume1" table="RESUME1">

<id name="resid" column="RESID" >

<generator class="native"></generator>

</id>

<property name="resname" column="RESNAME" type="string"></property>

<property name="rescardno" column="RESCARDNO" type="string"></property>

<many-to-one name="users1" class="Users1" cascade="all" column="RESUSERID" unique="true"></many-to-one>

</class>

</hibernate-mapping>

步骤三:测试方法书写

@Test

public void testAdd(){

Session session = HibernateUtil.getSession();

Transaction tx=session.beginTransaction();

//创建一个用户对象

Users1 u1=new Users1("happy","1");

//创建一个档案对象

Resume1 r1=new Resume1("小学档案","happy01");

u1.setResume1(r1);

r1.setUsers1(u1);

//保存r1自动保存u1

1.按照主键映射

步骤一:创建实体类Users2和Resume2

Users2的创建如下:

public class Users2 {

private Integer userid;

private String username;

private String userpass;

private Resume2 resume2;

}

Resume2的创建如下:

public class Resume2 {

private Integer resid;

private String resname;

private String rescardno;

private Users2 users2;

}

步骤二:配置文件Users1.hbm.xml和Resume1.hbm.xml

Users1.hbm.xml配置如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="cn.happy.onetoone_pk">

<class name="Users2" table="USERS2">

<id name="userid" column="USERID" >

<generator class="foreign">

<param name="property">resume2</param>

</generator>

</id>

<property name="username" column="USERNAME" type="string"></property>

<property name="userpass" column="USERPASS" type="string"></property>

<one-to-one name="resume2" class="Resume2" constrained="true"></one-to-one>

</class>

</hibernate-mapping>

Resume2.hbm.xml配置

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="cn.happy.onetoone_pk">

<class name="Resume2" table="RESUME2">

<id column="RESID" name="resid">

<generator class="native"/>

</id>

<property column="RESNAME" name="resname" type="string"/>

<property column="RESCARDNO" name="rescardno" type="string"/>

<one-to-one  name="users2" cascade="all" class="Users2"/>

</class>

</hibernate-mapping>

session.save(r1);

tx.commit();

System.out.println("ok===");

}

02.组件映射

建立关系数据模型的一个重要原则是在不会导致数据冗余的前提下,尽可能减少数据库表的数目及表之间的外键参照关系。以员工信息为例,员工信息中有员工的家庭地址信息,如果把地址信息单独放在一张表中,然后建立员工信息表和地址信息表之间的外键参照关系,当每次查询员工信息时,都需建立者两个表的连接。建立表的连接是很耗时的操作,为了提高数据库运行性能,可以把这两张表的信息整合在一张员工信息表EMPINFO中。

步骤一:创建EmpHomeAddress和EmpInfo

public class EmpHomeAddress {

private String ehomestreet;

private String ehomecity;

private String ehomeprovince;

private String ehomezipcode;

private EmpInfo empinfo;

}

EmpInfo创建如下:

public class EmpInfo {

private Integer eid;

private String ename;

private EmpHomeAddress ehome;

}

步骤二:创建配置文件EmpInfo.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="cn.happy.component">

<class name="EmpInfo" table="EMPINFO">

<id name="eid" column="EID">

<generator class="native"></generator>

</id>

<property name="ename" column="ENAME" type="string"></property>

<component name="ehome" class="EmpHomeAddress">

<parent name="empinfo"/>

<property name="ehomestreet" column="EHOMESTREET" type="string"></property>

<property name="ehomecity" column="EHOMECITY" type="string"></property>

<property name="ehomeprovince" column="EHOMEPROVINCE" type="string"></property>

<property name="ehomezipcode" column="EHOMEZIPCODE" type="string"></property>

</component>

</class>

</hibernate-mapping>

步骤三:书写测试类

@Test

public void testAdd(){

Session session = HibernateUtil.getSession();

Transaction tx=session.beginTransaction();

//创建一个员工对象

EmpInfo emp=new EmpInfo();

emp.setEname("张靓颖");

//创建一个员工地址对象

EmpHomeAddress address=new EmpHomeAddress();

address.setEhomecity("北京");

address.setEhomeprovince("北京");

address.setEhomestreet("五道口");

address.setEhomezipcode("100000");

address.setEmpinfo(emp);

emp.setEhome(address);

session.save(emp);

tx.commit();

System.out.println("ok===");

}

转载于:https://www.cnblogs.com/wdas-87895/p/6372118.html

hibernate.一对一关联相关推荐

  1. Hibernate一对一关联映射配置

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

  2. Hibernate 一对一关联查询

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

  3. Hibernate一对一关联------主键关联(亲测成功)

    1.创建两个实体(Company.java和Login.java)代码如下: 1 package wck.stu.vo.onetoonein; 2 3 public class Company { 4 ...

  4. Hibernate 一对一外键单向关联

    [align=center][size=medium]Hibernate 一对一外键单向关联[/size][/align] 基于外键关联的单向一对一关联和单向多对一关联几乎是一样的.唯一的不同就是单向 ...

  5. hibernate一对一主键关联映射(单向关联Person-----IdCard)

    一对一关联映射原理:让两个实体的主键一样,这样就不需要加入多余的字段 例子: package com.hibernate; public class IdCard { private int id; ...

  6. hibernate一对一主键唯一外键关联(一)

    1.新建工程项目hibernate_one2one_ufk_1,添加hibernate所需Jar包和数据库驱动Jar包. 2.编写工具类HibernateUtils.java和ExportDB.jav ...

  7. hibernate一对一主键唯一外键关联(二)

    1.新建工程项目hibernate_one2one_ufk_2,添加hibernate所需的Jar包和数据库驱动的Jar包. 2.编写工具类HibernatUtils.java和ExportDB.ja ...

  8. hibernate一对一主键关联映射(一)---单向关联

    1.新建工程项目hibernate_one2one_pk_1,添加hibernate所需Jar包和mysql驱动Jar包. 2.建立工具类HihernateUtils.java和ExportDB.ja ...

  9. Hibernate注解实现一对一关联

    本文使用Husband与Wife实现Hibernate的一对一关联.使用的数据库为SQL server 2005. 代码如下: Husband.java /*** */ package com.zha ...

最新文章

  1. nginx出现404和403错误
  2. C:\WINDOWS\Installer文件夹的安全清理
  3. tp 数据库查询排序_怎么进行数据库分库分表?
  4. 我的代码第一次运行时的样子
  5. 再谈strncpy函数--值得一看的好文章
  6. python之路《七》文件的处理
  7. 项目管理学习总结(7)——阿里云架构师:技术高手转向管理体会
  8. SQL Server商业智能–简介
  9. linux 5.4 安装php
  10. 这8个MySQL经典错误
  11. 分享一下苹果手机绕激活锁的体验
  12. 19 统计量及其抽样分布——样本均值的分布与中心极限定理
  13. 判断移动终端是安卓还是iOS
  14. 又一个奇葩要求,Python是如何将“中文”转“拼音”的?
  15. 网络协议之socket协议详解之Unix domain Socket
  16. 计算机上的科学计算器在哪里找,计算机的计算器在哪 自己的电脑上的计算器在哪里找...
  17. 微博登录显示服务器解析失败怎么办,微博air登录失败, air无法登录的原因 -电脑资料...
  18. 漫画|微信群聊的程序员们
  19. midaspay能删除吗_midaspay 什么意思
  20. 关于前端对象的一些絮叨

热门文章

  1. java变长参数_Java可变长度参数
  2. kettle查询数据库中文编码问题
  3. [转载]ASKING 邱宝裕 炒股 从十万到十亿
  4. glup 和 webpack 的不同之处总结
  5. WinDbg调试CPU占用高的问题 试验+实战 《第七篇》
  6. mysql中的存储过程优点_数据库存储过程在优点
  7. (二十二)岁月无声 - 8
  8. 『Oracle数据库容灾案例系列』国元证券Oracle容灾案例
  9. Java中接口和抽象类的区别
  10. 图解深度学习-波尔兹曼机