JPA一对多关系,在一端更新所包含多端引用的问题

在JPA一对多关系中,更新一端(School)的多端(Student)引用可能导致学生表中关联外键变为null。在JPA1.0中,解决此问题的方法包括数据库触发器和先删除再保存,但都有弊端。JPA2.0引入了`orphanRemoval=true`属性,可以自动删除多端中被移除的记录,避免外键完整性约束异常,有效解决了这个问题。
摘要由CSDN通过智能技术生成

在JPA一对多关系中,如

 

学校类:

 

 

 

学生类:

 

 

 

当我们在程序中更新School时,如:

当前School中有学生1,2,3。我们现在要将学生更新为1,3,4.

即重新set School类中的students集合,然后merge(更新)School对象。

 

但是当你查看数据库时会发现,school表中没有问题,但是student表里有问题了,学生2中关联school的外键为null了。

如果你在建表中约束了该外键不能为空的话,JPA会报sql外键完整性约束异常。

 

该问题在JPA1.0中没有比较好的解决办法,只好用两种比较不太好的办法解决:

1.在数据库中写一个触发器,清理student表中school外键为null的记录。

2.在更新时,先删除,在保存。这种性能是个严重的

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值