hibernate之OneToOne

本文深入探讨了在对象关系映射(ORM)中实现一对一关联的三种方法:主键关联、外键关联及中间表关联,并提供了具体的配置示例与测试代码。

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

这里使用学生和学生的详细信息表来表述,OneToOne有三种配置

1、主键关联

     主键关联是最复杂也是最常用的关联方式。

     配置如下:studentInfo主键生成策略,使用当前对象中student属性的主键来作为本对象的主键

	@Id
	@GeneratedValue(generator="pkGenerator")
	@GenericGenerator(name = "pkGenerator", strategy = "foreign", parameters = @Parameter(name = "property", value = "student"))
	private Integer id;
 

     //optional 关联属性可以为空 接连关系由StudentInfo的属性student维持

	@OneToOne(mappedBy="student",cascade=CascadeType.ALL,optional=true)
	//@Cascade(value={org.hibernate.annotations.CascadeType.ALL})
	private StudentInfo studentInfo ;


        //optional 关联属性不能为空
	@OneToOne(cascade={CascadeType.PERSIST,CascadeType.MERGE},optional=false)
	@PrimaryKeyJoinColumn
	private Student student;

 测试代码:

 

        @Test
	public void addStudent() {
		Student student = new Student("zyn", 22,20072724L);
		StudentInfo info = new StudentInfo("3444444","成都市");
		info.setStudent(student);
		this.studentInfoDao.save(info);
	}
 

 

2、外键关联,只需要修改StudentInfo中的student属性

     通过外键student_id关联

@OneToOne(cascade={CascadeType.PERSIST,CascadeType.MERGE},optional=false)
	//@PrimaryKeyJoinColumn
	
	@JoinColumn(name="student_id",nullable=false,unique=true)
	private Student student;
 

3、中间表关联

通过中间表student_and_info关联

@OneToOne(cascade = { CascadeType.PERSIST, CascadeType.MERGE }, optional = false)
	@JoinTable(name="student_and_info",joinColumns = @JoinColumn(name = "info_id"), inverseJoinColumns = @JoinColumn(name = "student_id"))
	private Student student;
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值