Hibernate之one-to-one双向外键关联Annotation

本文通过Husband和Wife类展示了Java中使用@OneToOne注解进行实体关系映射的方法,包括如何设置主键和外键,以及生成的SQL语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Husband.java

package com.itmyhome.model; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToOne; @Entity public class Husband { private int id; private String name; private Wife wife; /* * Id生成策略 mysql默认是auto_crement */ @Id @GeneratedValue public int getId() { return id; } public void setId(int id) { this.id = id; } /* * OneToOne * JoinColumn用来指定生成的外键名字 */ @OneToOne(fetch=FetchType.LAZY) @JoinColumn(name="wifeId") public Wife getWife() { return wife; } public void setWife(Wife wife) { this.wife = wife; } public String getName() { return name; } public void setName(String name) { this.name = name; } }


Wife.java

package com.itmyhome.model; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToOne; @Entity public class Wife { private int id; private String name; private Husband husband; @Id @GeneratedValue public int getId() { return id; } public void setId(int id) { this.id = id; } /* * 凡是双向必设mappedBy * 如果不设mappedBy 双方都会加外键约束 */ @OneToOne(mappedBy="wife") @JoinColumn(name="husbandId") public Husband getHusband() { return husband; } public void setHusband(Husband husband) { this.husband = husband; } public String getName() { return name; } public void setName(String name) { this.name = name; } }


hibernate生成的sql如下:

create table Husband ( id integer not null auto_increment, name varchar(255), wifeId integer, primary key (id) )


create table Wife ( id integer not null auto_increment, name varchar(255), primary key (id) ) alter table Husband add index FKAEEA401B78A8164D (wifeId), add constraint FKAEEA401B78A8164D foreign key (wifeId) references Wife (id)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值