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

在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.在更新时,先删除,在保存。这种性能是个严重的

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值