您的位置:首页 > 其它

Hibernate基于主键的一对一映射关系

2015-10-30 11:00 337 查看
<strong><span style="font-size:18px;"><span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">Hibernate中,一对一的映射关系有两种,一种是基于外键的一种是基于外键的,下面我来介绍一中基于主键的方式</span></span></strong>


首先创建两个实体类Person和IdCard,添加属性,生成相应的getter和setter方法。

然后就是Person.hbm.xml和IdCard.hbm.xml两个映射文件。

由于我把外键放到IdCard方,所以IdCard.hbm.xml做如下配置

<strong><span style="font-size:18px;"><?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 package="com.seven.domain">

<class name="IdCard" table="t_idCard">
<!-- 主键 -->
<id name="id" column="id">
<generator class="foreign">
<param name="property">person</param>
</generator>
</id>

<property name="number"/>
<!-- person属性,本方有外键 -->
<one-to-one name="person" class="Person" constrained="true"></one-to-one>
</class>

</hibernate-mapping></span></strong>
有外键方的主键生成策略一定要是foregin,然后加参数property,值为关联的对方的属性,这里是person

没有外键方的Person.hbm.xml配置如下

<strong><span style="font-size:18px;"><?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 package="com.seven.domain">

<class name="Person" table="t_person">
<!-- 主键 -->
<id name="id" column="id">
<generator class="native"/>
</id>

<property name="name"/>
<!-- idCard属性,本方无外键 -->
<one-to-one name="idCard" class="IdCard"></one-to-one>
</class>

</hibernate-mapping></span></strong>
最后写一个测试类来测试下保存数据,代码如下

<strong><span style="font-size:18px;">package com.seven.domain;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.junit.Test;

public class App {
private static SessionFactory sessionFactory = new Configuration()
.configure()//
.addClass(IdCard.class)//
.addClass(Person.class)//
.buildSessionFactory();
@Test
public void testSave(){
Session session = sessionFactory.openSession();
session.beginTransaction();

Person person = new Person();
person.setName("lkk");
IdCard idCard = new IdCard();
idCard.setNumber("32321321321");
//关联
person.setIdCard(idCard);
idCard.setPerson(person);
//保存
session.save(person);
session.save(idCard);

session.getTransaction().commit();
session.close();
}
}</span></strong>
最后在数据库中生成数据两个表




其中t_person 表中有一个主键和name字段,无外外键


t_idcard表中有一个引用t_person 主键的外键,也是表的主键
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: