java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Spring Data JPA @OneToOne

Spring Data JPA关系映射@OneToOne实例解析

作者:虚惊一百场

这篇文章主要为大家介绍了Spring Data JPA关系映射@OneToOne实例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

@OneToOne

表示一对一的映射关系,比如一个账号对应一个用户,一个实体用来描述账号的信息(账号,密码,账号是否可用,账号对应的角色等),另外一个实体用来描述用户的信息(昵称,性别,国籍等)。

属性

该注解有六个属性:

public @interface OneToOne {
    java.lang.Class targetEntity() default void.class;
    javax.persistence.CascadeType[] cascade() default {};
    javax.persistence.FetchType fetch() default javax.persistence.FetchType.EAGER;
    boolean optional() default true;
    java.lang.String mappedBy() default "";
    boolean orphanRemoval() default false;
}

关联关系

我们在使用的时候,通常为了保证表的简洁性,将主键共享,意思是用户的id和账号的id是一样的,不在表中单独存在一个字段用来描述关联关系;比如下面的例子:

创建账号实体

import org.hibernate.annotations.GenericGenerator;
import org.hibernate.annotations.Parameter;
import javax.persistence.*;
@Table(name = "base_account")
@Entity
@org.hibernate.annotations.Table(appliesTo = "base_account", comment = "账号信息表")
public class AccountDO {
    @Id
    @GenericGenerator(name="idGenerator", strategy = "uuid")
    @GeneratedValue(generator = "idGenerator")
    @Column(name = "ACCOUNT_ID", length = 32)
    private String accountId;
    @Column(name = "USERNAME", columnDefinition = "VARCHAR(32) NOT NULL COMMENT '账号'")
    private String username;
    @Column(name = "PASSWORD", columnDefinition = "VARCHAR(128) NOT NULL COMMENT '密码'")
    private String password;
    @OneToOne(cascade = {CascadeType.PERSIST, CascadeType.REMOVE, CascadeType.REFRESH})
    @PrimaryKeyJoinColumn
    private UserDO userDO;
    // 省略构造函数,get/set方法,toString方法等

创建一个用户信息实体

import org.hibernate.annotations.GenericGenerator;
import org.hibernate.annotations.Parameter;
import javax.persistence.*;
@Table(name = "base_user")
@Entity
@org.hibernate.annotations.Table(appliesTo = "base_user", comment = "用户信息表")
public class UserDO {
    @Id
    @GenericGenerator(name = "idGenerator", strategy = "foreign", parameters = @Parameter(name = "property", value = "accountDO"))
    @GeneratedValue(generator = "idGenerator")
    @Column(name = "USER_ID", length = 32)
    private String userId;
    @Column(name = "NICKNAME", columnDefinition = "VARCHAR(32) NOT NULL COMMENT '昵称'")
    private String nickname;
    @Column(name = "SEX", columnDefinition = "CHAR(2) DEFAULT NULL COMMENT '性别'")
    private String sex;
    @OneToOne(mappedBy = "userDO")
    private AccountDO accountDO;
        // 省略构造函数,get/set方法,toString方法等

用户实体的主键和账号实体的主键都使用一个生成策略,生成的id也一样,且在账号实体中使用@PrimaryKeyJoinColumn来声明在表中不建立对应的映射字段。

这里贴出源码,一个关系映射的小例子

以上就是Spring Data JPA关系映射@OneToOne实例解析的详细内容,更多关于Spring Data JPA @OneToOne的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文