zoukankan      html  css  js  c++  java
  • Hibernate入门之one to one关系映射详解

    前言

    本节开始我们正式步入关系映射的讲解,对于关系映射,在.NET或NET Core对于相关实体大多我们称之为主体和依赖体,而在java中称之为源实体和目标实体,只是叫法不同,本质上大同小异,文中若有错误之处,还望指正。

    one to one关系映射

    一对一关联可以是单向或双向的,在单向关联中,源实体具有一个关系字段,该关系字段引用目标实体,并且源实体的表包含外键,在双向关联中,每个实体(即源实体和目标实体)都有一个相互引用的关系字段,并且目标实体的表包含外键,源实体必须使用mappedBy属性来定义双向一对一映射,接下来我们分别来看单向关联和双向关联。

    单向关联

    这里我们分别给出所用到的两个对象Post和PostDetail,一篇博客发表只对应此篇博客详情,如下:

    @Entity
    public class Post {
    
        @Id
        @GeneratedValue
        private Long id;
    
        private String title;
    
        @OneToOne
        @JoinColumn(name = "post_detail_id")
        private PostDetail postDetail;
    
    }
    @Entity
    public class PostDetail {
    
        @Id
        @GeneratedValue
        private Long id;
    
        @Column(name = "created_on")
        private Date createdOn;
    
        @Column(name = "created_by")
        private String createdBy;
    
        public PostDetail() {
        }
    
        public PostDetail(String createdBy) {
            createdOn = new Date();
            this.createdBy = createdBy;
        }
    }

    如上单向关联中,通过源实体(Post)中的关系字段post_detail_id来引用目标实体,且此字段作目标实体(PostDetail)的外键,很明显像这种情况不符合实际情况,因为postdetail依赖于post。

    双向关联

    即便是一对一关系也会存在所属关系即目标实体依赖于源实体,所以上述post和postdetail关系是双向的,如果关系是双向的,则非拥有方(目标实体)必须使用属性mappedBy来指定拥有方的关系字段或属性。此时我们将post实体和postdetail实体修改成如下,而postdetail添加源实体。

    @Entity
    public class Post {
    
        @OneToOne(mappedBy = "post")
        private PostDetail postDetail;
    
    }
    
    @Entity
    public class PostDetail {
    
        @OneToOne
        private Post post;
    }

     

    上述我们在Post通过mappedBy添加了对目标实体PostDetail的所属关系,同时在PostDetail添加了对Post的关联,此时我们可以看到默认生成的外键为post_id即(源实体名称 + '_' + id),若需要修改外键名称,直接通过注解@JoinColumn显式指定外键名称,比如如下指定为custom_post_id。

    分析到这里为止,其实对于一对一关系映射配置还是非常简单,我们只需要根据业务搞清楚所属关系,然后通过mappedBy指定,最终可以默认或显式指定外键名称,有的童鞋可能就问了,要是我想将实体PostDetail中的外键post_id也作为主键呢,也就是说将post_id作为共享主键,此时我们应该怎么办呢?此时实体PostDetail中的主键id将不再是自动生成,去除自动生成注解,然后通过注解@MapsId来指定源实体,改造后的实体PostDetail如下

    @Entity
    public class PostDetail {
    
        @Id
        private Long id;
    
        @OneToOne
        @MapsId
        private Post post;
    }

    虽然我们达到了共享主键的目的,但是在PostDetail表中其主键名称为post_id,如果感觉不太友好或者不太好理解,那就继续通过注解@JoinColumn指定名称为id,如下:

    @Entity
    public class PostDetail {
    
        @Id
        private Long id;
    
        @OneToOne
        @MapsId
        @JoinColumn(name = "id")
        private Post post;
    }

    总结

    本节我们详细讲解了一对一关系映射,无论是单向关联还是双向关联根据实际业务而定,大部分情况下需要通过注解@mappedBy来进行双向关联,同时呢,我们也可以通过注解@MapsId来配置共享主键。好了,本节到此结束,下一节我们进入一对多关系映射的讲解。

  • 相关阅读:
    使用MFC界面库LibUIDK制作超酷界面
    使用WSH和WMI实现定时记录系统CPU和内存使用率
    关于CreateFileMapping的问题
    360对NSIS误报Malware.QVM06.GEN的解决办法
    win2003实现单用户远程登录
    All bytes must be within the maximum size specified by CreateFileMapping
    解决在VS2005中“当前不会命中断点。源代码与原始版本不同”的问题
    static library中能不能带资源
    HUDSON_HOME
    USB GUID查找
  • 原文地址:https://www.cnblogs.com/CreateMyself/p/12434145.html
Copyright © 2011-2022 走看看