@OneToOne
, 表示一對一的映射關係,好比一個帳號對應一個用戶,一個實體用來描述帳號的信息(帳號,密碼,帳號是否可用,帳號對應的角色等),另一個實體用來描述用戶的信息(暱稱,年齡,性別,國籍等)。java
該註解有六個屬性:git
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; }
targetEntity
關聯目標實體類,指定類型後該屬性可省略;cascade
表示關聯關係中的級聯操做權限,有五種權限:github
CascadeType.PERSIST
:級聯新增(又稱級聯保存);CascadeType.MERGE
:級聯合並,更新該實體時,與其有映射關係的實體也跟隨更新;CascadeType.REMOVE
:級聯刪除,刪除該實體時,與其有映射關係的實體也跟隨刪除;CascadeType.REFRESH
:級聯刷新,該實體被操做前都會刷新,保證數據合法性;CascadeType.ALL
:包含以上四種級聯操做;fetch
數據加載策略,默認值爲FetchType.EAGER
:app
FetchType.LAZY
表示數據獲取方式爲懶加載;FetchType.EAGER
表示數據獲取方式爲急加載;optional
表示關聯關係是否必須,當該值爲true
時,one
的一方能夠爲null
;mappedBy
指定映射關係由哪一方維護,通常使用在雙向映射場景;orphanRemoval
孤值刪除,將會刪除孤立數據,外鍵爲null的數據將被刪除;咱們在使用的時候,一般爲了保證表的簡潔性,將主鍵共享,意思是用戶的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方法等
建立一個用戶信息實體fetch
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 = "AGE", columnDefinition = "TINYINT DEFAULT NULL COMMENT '年齡'") private Integer age; @Column(name = "SEX", columnDefinition = "CHAR(2) DEFAULT NULL COMMENT '性別'") private String sex; @OneToOne(mappedBy = "userDO") private AccountDO accountDO; // 省略構造函數,get/set方法,toString方法等
用戶實體的主鍵和帳號實體的主鍵都使用一個生成策略,生成的id
也同樣,且在帳號實體中使用@PrimaryKeyJoinColumn
來聲明在表中不創建對應的映射字段。ui
這裏貼出源碼,一個關係映射的小例子hibernate
原創不易,感謝支持。code