码迷,mamicode.com
首页 > 其他好文 > 详细

一对一关联映射

时间:2016-09-05 17:05:28      阅读:221      评论:0      收藏:0      [点我收藏+]

标签:

 

Hibernate提供了两种映射一对一关联关系的方式:按照外键映射和按照主键映射。

 

下面以员工账号和员工档案表为例,介绍这两种映射方式:

1.按照外键映射

     技术分享

步骤一:创建实体类Users1Resume1

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.xmlResume1.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>

步骤三:测试方法书写

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
	   session.save(r1);
	   tx.commit();
	   System.out.println("ok===");
  }

 

2.按照主键映射

 技术分享

步骤一:创建实体类Users2Resume2

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.xmlResume1.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>

  

 

一对一关联映射

标签:

原文地址:http://www.cnblogs.com/yangronglin/p/5842592.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!