hibernate注解之实体属性OneToOne 单双向关联(三)

来源:互联网 发布:手机宣传视频制作软件 编辑:程序博客网 时间:2024/06/04 17:56

一对一(One-to-one)
 
使用@OneToOne注解可以建立实体bean之间的一对一的关联. 一对一关联有三种情况: 一是关联的实体都共享同样的主键, 二是其中一个实体通过外键关联到另一个实体的主键
(注意要模拟一对一关联必须在外键列上添加唯一约束). 三是通过关联表来保存两个实体之间的连接关系 (注意要模拟一对一关联必须在每一个外键上添加唯一约束).

首先,我们通过共享主键来进行一对一关联映射:
我们用丈夫和妻子的关系来形容这种关系。
1.关联实体共享主键
官方文档解释
@Entity
public class Body {
    @Id
    public Long getId() { return id; }

    @OneToOne(cascade = CascadeType.ALL)
    @PrimaryKeyJoinColumn
    public Heart getHeart() {
        return heart;
    }
    ...
}
           
@Entity
public class Heart {
    @Id
    public Long getId() { ...}
}

自己的例子:共享主键的话,主体的id需要是外键。

 

wife的class 的id就用uuid,hibernate自动生成吧。

 

 
 
 
配置文件:(配置文件只在这里给出,下面的一对多,多对一的配置文件只需在上面做小小的改动即可,改动的地方就是mapping)
 
<span style="font-size:18px;"><script src="https://code.csdn.net/snippets/496943.js"></script></span>

@OneToOne         建立实体 bean 之间的一对一的关联

cascade                  级联策略,即,当对主对象做某种操作时,是否对其相关联的子对象也做相对应的操作。它有5个值可选,分别是 :

             CascadeType.PERSIST : 级联新建

             CascadeType.REMOVE  :  级联删除

             CascadeType.REFRESH : 级联刷新

             CascadeType.MERGE   : 级联更新

             CascadeType.ALL     : 囊括以上四项

fetch                        抓取策略,它有2个值可选,分别是 :

             FetchType.LAZY   :   延迟抓取

             FetchType.EAGER  :   立即抓取

Tips :       延迟抓取数据能够保证应用只有在需要的时候才去数据库抓取相应的数据记录,这样能够避免过多,

             或过早的加载数据库表中的数据,从而减少应用内存的开销。

@JoinColumn     该注解与@Column 注解用法有点相似,可以通过name来指定联接列的名称,如果没有该注解没有被声明,

             默认的联接列名称是 : 关联的类的短类名(首字母小写,不带包名)_id。

@OneToOne         建立实体 bean 之间的一对一的关联

cascade                  级联策略,即,当对主对象做某种操作时,是否对其相关联的子对象也做相对应的操作。它有5个值可选,分别是 :

             CascadeType.PERSIST : 级联新建

             CascadeType.REMOVE  :  级联删除

             CascadeType.REFRESH : 级联刷新

             CascadeType.MERGE   : 级联更新

             CascadeType.ALL     : 囊括以上四项

fetch                        抓取策略,它有2个值可选,分别是 :

             FetchType.LAZY   :   延迟抓取

             FetchType.EAGER  :   立即抓取

Tips :       延迟抓取数据能够保证应用只有在需要的时候才去数据库抓取相应的数据记录,这样能够避免过多,

             或过早的加载数据库表中的数据,从而减少应用内存的开销。

@JoinColumn     该注解与@Column 注解用法有点相似,可以通过name来指定联接列的名称,如果没有该注解没有被声明,

             默认的联接列名称是 : 关联的类的短类名(首字母小写,不带包名)_id。

 

mappedBy :

    相当于 xml 方式配置的 inverse = "true",表示将表间关联的这种关系的维护交给对方,对方才是关系的真正维护者,拥有主导权。

    在双向关联中,有且仅有一端是作为主体( owner )端存在,主体端负责维护联接列。对于不需要维护这种关系的从表则通过 mappedBy 属性进行声明。

    最后不必也不能再在被关联端(owned side)定义联接列了,因为已经在主体端进行了声明.

 
通过关联表来保存两个实体之间的连接关系,这个感觉冗余一个表没什么性能改善,就不介绍了。

 

0 0