JPA 一对多关联数据更新踩坑记录

在一组一对多关联管理中,我的需求是原来一个项目中有3个图片信息,我现在删掉2个 把剩下的1个图片对象和项目信息一起传给项目的Repository.save,我想要的结果是我其他2个图片信息的外键值置空,只留我要保存的那一个,然而一开始我的关联关系设置成如下:

@ApiModelProperty(value = "点检项目")
@ManyToOne(cascade={CascadeType.ALL} optional=false)//,fetch = FetchType.EAGER,
@NotFound(action = NotFoundAction.IGNORE)
@Where(clause = "delete_flag=0")
@JoinColumn(name = "r_id",referencedColumnName = "id")
@JsonIgnoreProperties("equipInstDetailRecordPics")
private FtpmEquipInstDetailRecord equipInstDetailRecord
/**
 *点检项拍照
 * **/
@OneToMany(cascade={CascadeType.DETACH}, mappedBy = "equipInstDetailRecord")//fetch = FetchType.LAZY,orphanRemoval = true
@Where(clause="delete_flag=0")
@JsonIgnoreProperties("equipInstDetailRecord")
// @JSONField(serialize = false)
private List<FtpmEquipInstDetailRecordPic> equipInstDetailRecordPics;

很神奇的结果是 把我传的要保存的对象的外键置空了,其他的数据和外键反而还在,和我的需求刚刚相反。

然后一番尝试后把@ManyToOne里面的属性注释掉,然后在@OneToMany(cascade={CascadeType.PERSIST}, fetch = FetchType.LAZY, mappedBy = "equipInstDetailRecord")设备成这样的时候对多图片数据便不做任何操作,成功第一步,主要是CascadeType.PERSIST维护了更新数据,然后再加上orphanRemoval = true表示当移除了实体的关系的时候,会自动删除对应的实体  就达到了一开始的目标需求,只是把多的数据直接删除了 而不是仅对外键置空

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值