欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

关于jpa中无法删除onetomany中many问题的解决

时间:2023-02-10 10:12:23|栏目:JAVA代码|点击:

jpa 无法删除onetomany中many问题

问题描述

今天在做项目遇到一个问题,建立两个实体order和orderDetail,他们是onetomany关系,当我想要之间删除一个orderDetail时,发现不能删除但是程序也不出错。

实体建立模型如下图:

order中:

在这里插入图片描述

orderDetail中:

在这里插入图片描述

解决思路

1.首先我想到了直接删除orderDetail不行,是否可以直接通过update order的关联关系进行级联删除啦,于是写了一下代码

在这里插入图片描述

结果发现这样是可以删除orderDetail,但是这种删除方式并不是我想要的,而且感觉也不是最好的解决方法。

2.在结合上一种方法实现成功后,突然想到是否是关联关系建立的原因,如果我先把关联关系断开,在进行删除orderDetail是否能成功:

在这里插入图片描述

结果证明,成功删除

小结一下

虽然实现了我想要的功能,但是jpa的删除具体逻辑还需要深入研究。自我感觉是因为order是关系维护方,想要删除many端就必须先断开关系在进行删除

jpa @OneToMany 删除不了集合数据

在使用jpa的时候,如果有@OneToMany关系。想删除many的单个数据。有时候删除不了。 jap关系如下:一个用户对应多个角色。并且user实体中CascadeType.ALL

//user实体
@OneToMany(cascade = CascadeType.ALL,fetch= FetchType.LAZY,mappedBy = "user")
    private Set<Role> roles = new HashSet<Role>();

//role实体
@ManyToOne(fetch= FetchType.LAZY)
    @JoinColumn(name="user_id")
    private User user;

这时候如果想删除role

必须做2个事情:

1、删除role。

2、把role从集合roles中移除。

如下:

roleRepo.delete(role);//这里删除操作需要delete和从集合中remove一起操作才能生效
user.getRoles().remove(role);
userService.update(user);

如果不这样操作。就会不生效。

参考文档: https://stackoverflow.com/questions/2011519/jpa-onetomany-not-deleting-child

上一篇:SpringBoot整合Mybatis-plus的具体使用

栏    目:JAVA代码

下一篇:Java8中CompletableFuture使用场景与实现原理

本文标题:关于jpa中无法删除onetomany中many问题的解决

本文地址:http://www.codeinn.net/misctech/225459.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有