人和身份证之间就是一个典型的一对一关联关系。实现一对一关联关系映射的方式有两种一种是基于外键,一种是基于主键,下面我们先看基于外键的关联方式

首先看他们的实体类

Person类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
package entity;
 
public class Person {
    private Integer id;
    private String name;
    private IdCard idCard;
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public IdCard getIdCard() {
        return idCard;
    }
    public void setIdCard(IdCard idCard) {
        this.idCard = idCard;
    }
}

然后看IdCard类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package entity;
 
public class IdCard {
    private Integer id;
    private String number;
    private Person person;
     
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getNumber() {
        return number;
    }
    public void setNumber(String number) {
        this.number = number;
    }
    public Person getPerson() {
        return person;
    }
    public void setPerson(Person person) {
        this.person = person;
    }
     
     
}

这里在Person类和IdCard类中分别有一个对方类型的属性。

然后看他们之间的关联关系映射,首先看Person.hbm.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 
<hibernate-mapping>
    <class name="entity.Person" table="Person" schema="MYHR">
        <id name="id" type="int">
            <column name="ID" />
            <generator class="assigned" />
        </id>
        <property name="name" type="string">
            <column name="NAME" not-null="true" />
        </property>
        <!-- idCard属性,IdCard类型,表达本类与IdCard的一对一关联 -->
        <!-- 采用基于外键的一对一,本方无外键方 -->
        <!-- property-ref属性:对方映射中外键类对应的属性名 -->
        <one-to-one name="idCard" class="entity.IdCard" property-ref="person">
        </one-to-one>
    </class>
</hibernate-mapping>

然后看一下IdCard.hbm.xml文档

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
<hibernate-mapping>
    <class name="entity.IdCard" table="IdCard" schema="MYHR">
        <id name="id">
            <column name="ID"/>
            <generator class="assigned" />
        </id>
        <property name="number">
            <column name="NAME" not-null="true" />
        </property>
        <!-- person属性,Person类型,表示与Person类的一对一关联关系 -->
        <!-- 采用基于外键的一对一关联方式,本方有外键 -->
        <many-to-one name="person" column="personId" class="entity.Person" unique="true"></many-to-one>
    </class>
</hibernate-mapping>

这样Person和IdCard之间的一对一关联关系就搭建好了,然后看一下测试类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
package test;
 
import static org.junit.Assert.*;
 
import org.hibernate.Session;
import org.hibernate.Transaction;
 
import entity.IdCard;
import entity.Person;
import factory.HibernateSessionFactory;
 
public class Test {
 
    private Session session = null;
    private Transaction tran = null;
    @org.junit.Test
    public void save() {
        session = HibernateSessionFactory.getSession();
        tran = session.beginTransaction();
        try{
            //新建对象
            Person p = new Person();
            p.setId(1);
            p.setName("张三");
             
            IdCard idCard = new IdCard();
            idCard.setId(1);
            idCard.setNumber("10001");
             
            p.setIdCard(idCard);
            idCard.setPerson(p);
             
            session.save(p);
            session.save(idCard);
             
            tran.commit();
        }catch(Exception e){
            tran.rollback();
        }
    }
 
    @org.junit.Test
    public void Get() {
        session = HibernateSessionFactory.getSession();
        tran = session.beginTransaction();
        try{
            Person person = (Person) session.get(Person.class, 1);
            IdCard idCard = person.getIdCard();
            System.out.println(person.getName()+"身份证号:"+idCard.getNumber());
            tran.commit();
        }catch(Exception e){
            tran.rollback();
        }
    }
    //解除关系
    @org.junit.Test
    public void RemoveRelation() {
        session = HibernateSessionFactory.getSession();
        tran = session.beginTransaction();
        try{
            //从有外键方接触关联关系可以,不可以从无外键方解除
            IdCard idCard = (IdCard)session.get(IdCard.class, 1);
            idCard.setPerson(null);
            tran.commit();
        }catch(Exception e){
            tran.rollback();
        }
    }
    //删除
    @org.junit.Test
    public void DeleteRelation() {
        session = HibernateSessionFactory.getSession();
        tran = session.beginTransaction();
        try{
            //如果没有关联对方,可以直接删除。
            //如果有关联对方,且可以维护关联关系,他就会先删除关联关系,在删除自己。
            //如果有关联关系,且不能维护关联关系,所以会执行删除自己,并且抛出异常。
            IdCard idCard = (IdCard)session.get(IdCard.class, 1);
            session.delete(idCard);
            tran.commit();
        }catch(Exception e){
            tran.rollback();
        }
    }
}

这就是基于外键方式,基于主键的方式只需要在以上基础修改一下映射文件即可,下面分别看一下修改后的映射文件

首先看Person.hbm.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 
<hibernate-mapping package="entity">
    <class name="entity.Person" table="Person" schema="MYHR">
        <id name="id" type="int">
            <column name="ID" />
            <generator class="assigned" />
        </id>
        <property name="name" type="string">
            <column name="NAME" not-null="true" />
        </property>
        <!-- idCard属性,IdCard类型,表达本类与IdCard的一对一关联 -->
        <!-- 采用基于主键的一对一,本方无外键方 -->
        <one-to-one name="idCard" class="entity.IdCard"/>
       
    </class>
</hibernate-mapping>

然后看IdCard.hbm.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
<hibernate-mapping package="entity">
    <class name="entity.IdCard" table="IdCard" schema="MYHR">
        <id name="id" type="int">
            <column name="ID" />
            <!-- 当使用基于主键的一对一映射时,有外键方的主键生成策略是foreign, -->
            <!-- 参数property:生成主键值时所根据的对象 -->
            <generator class="foreign">
                <param name="property">person</param>
            </generator>
        </id>
        <property name="number" type="string">
            <column name="NAME" not-null="true" />
        </property>
        <!-- person属性,Person类型,表示与Person类的一对一关联关系 -->
        <!-- 采用基于主键的一对一关联方式,本方有外键 -->
        <one-to-one name="person" class="entity.Person"
            constrained="true" />
    </class>
</hibernate-mapping>

Hibernate关联关系映射之一对一关联关系的更多相关文章

  1. Hibernate关联关系映射之一对一(主键关联)

    在业务成的域模型中,类和类之间最普遍的关系就是关联关系,而关联也是有方向的. 就以例子来说明:一个人对应一张身份证.对其进行增删改. 对于人在数据创建表的时候,我们就给他两个字段,一个是id号,一个就 ...

  2. Hibernate之基于主键映射的一对一关联关系

    1. 基于主键的映射策略:指一端的主键生成器使用foreign策略,表明根据"对方"的主键来生成自己的主键,自己并不能独立生成主键.并用<param> 子元素指定使用当 ...

  3. Hibernate 基于外键映射的一对一关联关系随手记

    //有外键的一端默认使用懒加载. //没有外键的一端不使用懒加载,而是直接将它引用的对象也一并查询出来. //没有外键列不仅有外键约束还有唯一约束,即没有外键列一端的对象不能被有外键列一端的两个对象同 ...

  4. Hibernate关联映射1:一对一主键关联

    2张表之间通过主键形成一对一映射关系,如一个人只能有一张身份证: t_identity_card表建表语句: CREATE TABLE `t_identity_card` ( `id` int(11) ...

  5. Hibernate之关联关系映射(一对一主键映射和一对一外键映射)

    1:Hibernate的关联关系映射的一对一外键映射: 1.1:第一首先引包,省略 1.2:第二创建实体类: 这里使用用户信息和身份证信息的关系,用户的主键编号既可以做身份证信息的主键又可以做身份证信 ...

  6. 一对一关联关系基于主键映射的异常 IdentifierGenerationException

    具体异常:org.hibernate.id.IdentifierGenerationException: attempted to assign id from null one-to-one pro ...

  7. [原创]java WEB学习笔记82:Hibernate学习之路---映射 一对多关联关系,配置,CRUD方法测试及注意点

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  8. mybatis一对多关联关系映射

    mybatis一对多关联关系映射 一对多关联关系只需要在多的一方引入少的一方的主键作为外键即可.在实体类中就是反过来,在少的一方添加多的一方,声明一个List 属性名 作为少的一方的属性. 用户和订单 ...

  9. 分享知识-快乐自己:Hibernate 关联映射

    关联关系映射--概念: 关联关系是使用最多的一种关系,非常重要.在内存中反映为实体关系,映射到DB中为主外键关系. 实体间的关联,即对外键的维护.关联关系的发生,即对外键数据的改变. 外键:外面的主键 ...

随机推荐

  1. django用户认证系统——基本设置1

    网站提供登录.注册等用户认证功能是一个常见的需求.因此,Django 提供了一套功能完整的.灵活的.易于拓展的用户认证系统:django.contrib.auth.在本教程中,我将向你展示 auth ...

  2. Storm的组件

    摘自网上 当时写的很好,很详细的介绍了各个组件直接的关系 Storm集群和Hadoop集群表面上看很类似.但是Hadoop上运行的是MapReduce jobs,而在Storm上运行的是拓扑(topo ...

  3. gitlab 阿里邮箱配置

    gitlab 阿里邮箱配置 # gitlab_rails['smtp_user_name'] = "smtp user"# gitlab_rails['smtp_password' ...

  4. 搜索过滤grep(win下为findstr)

    搜索过滤grep(win下为findstr) 1.主要参数 [options]主要参数: -c:只输出匹配行的计数. -i:不区分大小写 -h:查询多文件时不显示文件名. -l:查询多文件时只输出包含 ...

  5. 汇编学习笔记(AT&T语法)

    一个最基本的汇编程序如下所示: .section .data .section .text .globl _start _start: movl $, %eax # the number 1 is t ...

  6. python线程池应用场景-爬虫

    import requests from bs4 import BeautifulSoup from concurrent.futures import ThreadPoolExecutor, Pro ...

  7. MySQL数据库(3)- 完整性约束、外键的变种、单表查询

    一.完整性约束 在创建表时候,约束条件和数据类型的宽度都是可选参数. 作用:用于保证数据的完整性和一致性. 1.not null(不可空)与default 示例一:插入一个空值,如下: mysql&g ...

  8. 如何做好部门以及公司的文档管理、知识管理以及情报管理?——By Me

    之前针对部门的文档管理开发平台进行过一次需求调研分析,对于实现方案与我们的实际需求之前的满足情况系统梳理了一下,我觉得对于有类似需求的团队或者公司应该有可以借鉴的地方,发到这里供大家参考.如有不正之处 ...

  9. (4.1)SQL Server Browser 与动态端口

    转自:http://blog.51cto.com/jimshu/1120295 一.启用TCP端口 1.启用TCP/IP协议 打开SSCM(SQL Server Configuration Manag ...

  10. 搭建ss的步骤

    1. 购买vultr产品 购买地址 (这个比较稳定) 2. 更改ssh的端口,混淆一下,我改成了2333 vim /etc/ssh/sshd_config 将里面的port改为2333 更改防火墙规则 ...