【SSH系列】Hibernate映射 -- 一对一单向关联映射

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

               

       映射原理
       一对一关联映射:两个实体对象之间是一对一的关联映射,即一个对象只能与另外唯一的一个对象相对应。有两种策略可以实现一对一的关联映射:
       a、主键关联:即让两个对象具有相同的主键值,以表明她们之间的一一对应的关系;数据库表不会有额外的字段来维护她们之间的关系,仅通过表的主键来关联。
       b、唯一外键关联:外键关联,本来适用于多对一的配置,但是如果加上唯一的限制之后,也可以表示一对一关联关系,谈恋爱就是一一对应,一个男朋友对应一个女朋友,如果不是,只能说明道德问题,ok,再比如,我们每个人(person)只能有一张身份证(IdCard),不需要多余的外键字段来维护关系,仅通过主键来关联,即Person的主键要依赖IdCard的主键,他们共用一个主键值。接着,小编就person和idCard为例,讲解两种策略实现一对一的关联映射。不足之处,还请小伙伴们多多指教`(*∩_∩*)′。
      小编依然从uml图入手,了解她们的对象模型和关系模型,首先我们来看一对一的对象模型,类图如下所示:
                            

      从上面的uml类图包括实际生活中,我们很容易得出结论,一个人只有一张身份证,并且我们的身份证号码都是唯一的,因为我们每个人都是独一无二的Person和IdCard之间是一一对一的关系,Person持有IdCard的引用,所以,两个对象关系维护由Person端来决定。ok,接下来,小编分别讲解一对一单向关联映射的两种策略。

        主键关联
        根据上面的对象模型,我们画出下面的关系模型,如下所示:
              

        在博文的开头,小编已经介绍过,主键关联,即让两个对象具有相同的主键值,以表明她们之间的一一对应的关系;数据库表不会有额外的字段来维护她们之间的关系,仅通过表的主键来关联。结合我们person和idCard的例子,就是Person的主键要依赖IdCard的主键,他们共用一个主键值。 ok,接着,我们开始编写相应的代码。

       第一步、建立项目,编写Pserson和Person两个实体类,并且生成get和set方法代码如下所示,首先是Person类:

package com.bjpowernode.hibernate;public class Person private int id; private String name; private IdCard idCard; public int getId() {  return id; } public IdCard getIdCard() {  return idCard; } public void setIdCard(IdCard idCard) {  this.idCard = idCard; } public void setId(int id) {  this.id = id; } public String getName() {  return name; } public void setName(String name) {  this.name = name; } }

       接着IdCard类,代码如下所示:

package com.bjpowernode.hibernate;public class IdCard private int id; private String cardNo; public int getId() {  return id; } public void setId(int id) {  this.id = id; } public String getCardNo() {  return cardNo; } public void setCardNo(String cardNo) {  this.cardNo = cardNo; } }
       第二步、编写Person.hbm.xml和IdCard.hbm.xml文件中的代码,首先Person.hbm.xml代码如下所示:

<?xml version="1.0"?><!DOCTYPE hibernate-mapping PUBLIC  "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"><hibernate-mapping> <class name="com.bjpowernode.hibernate.Person" table="t_person">  <id name="id">   <!-- 采用foreign生成策略,forgeign会取得关联对象的标识 -->   <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></hibernate-mapping>
        接着编写IdCard.hbm.xml的代码,如下所示:

<?xml version="1.0"?>  <!DOCTYPE hibernate-mapping PUBLIC       "-//Hibernate/Hibernate Mapping DTD 3.0//EN"      "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  <hibernate-mapping>      <class name="com.bjpowernode.hibernate.IdCard" table="t_idCard">       <id name ="id">      <generator class="native"/>     </id>      <property name="cardNo"/>                     </class>        </hibernate-mapping>
       第三步、编写hibernate.cfg.xml的代码,建立数据库并且添加相应的映射,代码如下所示:
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"><hibernate-configuration> <session-factory >  <!-- MySql数据库驱动 -->  <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>  <!-- 数据库名称 -->   <property name="hibernate.connection.url"> jdbc:mysql:///hibernate_one2one_pk_1</property>  <!-- 数据库的用户名 -->  <property name="hibernate.connection.username">root</property>  <!-- 数据库的密码 -->  <property name="hibernate.connection.password">123456</property>  <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>  <!-- 显示语句 -->          <property name="hibernate.show_sql">true</property>          <!-- 格式排版 -->          <!-- <property name="hibernate.format_sql">true</property> -->          <mapping resource="com/bjpowernode/hibernate/Person.hbm.xml"/>   <mapping resource="com/bjpowernode/hibernate/IdCard.hbm.xml"/> </session-factory></hibernate-configuration>
       接着,创建数据库,并且运行ExportDB,效果如下所示:

       

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值