Hibernate双向一对一外键关联

设置一对一双向外键关联关系,通过Husband可以找到Wife,也能通过Wife找到Husband


1、编写Husband类,并在Husband中添加Wife的引用 ;
使用Annotation时,将实体类进行注解,@Entity 、@Id;同时添加注解,设置关联关系为@OneToOne ;

[java] view plain copy print ?
  1. package com.hibernate._0700_one2one_bi_fk;
  2. import javax.persistence.Entity;
  3. import javax.persistence.GeneratedValue;
  4. import javax.persistence.Id;
  5. import javax.persistence.JoinColumn;
  6. import javax.persistence.OneToOne;
  7. /**双向一对一外间关联,*/
  8. @Entity
  9. public class Husband {
  10. private Integer id;
  11. private String name;
  12. private Wife wife; //去参考wife的id,此时wife必须先id
  13. @Id
  14. @GeneratedValue
  15. public Integer getId() {
  16. return id;
  17. }
  18. public String getName() {
  19. return name;
  20. }
  21. @OneToOne //设置关联关系
  22. @JoinColumn(name="wifeId") //指定数据库中的名字,默认为wife_id
  23. public Wife getWife() {
  24. return wife;
  25. }
  26. public void setId(Integer id) {
  27. this.id = id;
  28. }
  29. public void setName(String name) {
  30. this.name = name;
  31. }
  32. public void setWife(Wife wife) {
  33. this.wife = wife;
  34. }
  35. }

2、编写实体类Wife,并在Wife中引用Husband;
[java] view plain copy print ?
  1. package com.hibernate._0700_one2one_bi_fk;
  2. import javax.persistence.Entity;
  3. import javax.persistence.Id;
  4. import javax.persistence.OneToOne;
  5. @Entity
  6. public class Wife {
  7. private Integer id;
  8. private String name;
  9. private Husband husband;
  10. /** mappedBy="wife"中的这个wife是Husband中的wife属性,表示Husband起主导作用
  11. 如果不加,在数据库中Wife表中会生成husband_id这个冗余字段*/
  12. @OneToOne(mappedBy="wife")
  13. public Husband getHusband() {
  14. return husband;
  15. }
  16. @Id
  17. public Integer getId() {
  18. return id;
  19. }
  20. public String getName() {
  21. return name;
  22. }
  23. public void setHusband(Husband husband) {
  24. this.husband = husband;
  25. }
  26. public void setId(Integer id) {
  27. this.id = id;
  28. }
  29. public void setName(String name) {
  30. this.name = name;
  31. }
  32. }
使用Annotation时,将实体类进行注解,@Entity 、@Id;

同时也设置设置关联关系为@OneToOne,但是此时要加上属性mappedBy属性,

mappedBy="wife"中的这个wife是Husband中的wife属性,表示Husband起主导作用。
如果不加,在数据库中Wife表中会生成husband_id这个冗余字段;


3、编写测试类,生成数据库表,查看表的关系;

4、在xml文件中,在class标签中设置关联关系。
在Husband.hbm.xml 配置文件中介入

<many-to-one name="wife" column="wifeId" unique="true"></many-to-one>
unique="ture" 约束成一对一关联;

在Wife.hbm.xml 中添加

<one-to-one name="husband" property-ref="wife"></one-to-one>

property-ref指的是与之关联的类Husband中的属性wife。


5、总结:

凡是双向关联,mappedBy必设。

你可能感兴趣的:(Hibernate双向一对一外键关联)