我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

jpa中无法删除onetomany中many怎么办

这篇文章主要介绍“jpa中无法删除onetomany中many怎么办”,在日常操作中,相信很多人在jpa中无法删除onetomany中many怎么办问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”jpa中无法删
2023-06-21

如何解决网站中了木马无法删除的问题

本篇内容介绍了“如何解决网站中了木马无法删除的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  首先要找到木马!  我们使用D盾扫描了一
2023-06-10

linux bash中too many arguments问题的解决方法

判断一个文件的内容是不是为空,使用语句: if test -z `cat filename` 当filename为空或者只有一行没有空格的字符串的时候,一切正常,反之,则会报:too many arguments,甚至是: binary o
2022-06-04

关于Element-ui中Table表格无法显示的问题及解决

这篇文章主要介绍了关于Element-ui中Table表格无法显示的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

php中unlink无法删除的解决方法

这篇文章主要介绍php中unlink无法删除的解决方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!php unlink无法删除是因为没有执行fclose,其解决办法:首先创建一个PHP示例文件;然后通过fopen打
2023-06-09

如何解决虚拟机无法删除快照的问题

要解决虚拟机无法删除快照的问题,可以尝试以下方法:检查虚拟机存储空间:确保虚拟机的存储空间足够,以便删除快照时能够存储新的数据。检查快照状态:确认快照是否处于活动状态,如果是,则尝试将虚拟机还原到快照创建前的状态,然后再尝试删除快照。检查虚
如何解决虚拟机无法删除快照的问题
2024-06-11

关于 MySQL 嵌套子查询中无法关联主表字段问题的解决方法

今天在工作中写项目的时候,遇到了一个让我感到几乎无解的问题,在转换了思路后,想出了一个折中的解决方案,记录如下。其实,问题的场景,非常简单:就是需要查询出上图的数据,红框是从 项目产品表 中查询的2个字段,绿框是从与项目产品表关联的 文章
2022-12-26

关于MySQL嵌套子查询中无法关联主表字段问题的解决方法

这篇文章主要介绍了关于MySQL嵌套子查询中,无法关联主表字段问题的折中解决方法,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-26

docker中nacos无法访问的问题解决

Docker中Nacos无法访问的解决方案:检查端口映射和容器网络验证防火墙规则并检查容器健康状况更新Nacos配置和环境变量重新启动Nacos容器并查看代理日志启用端口转发和检查容器权限若问题持续,请联系Nacos支持团队
docker中nacos无法访问的问题解决
2024-04-02

关于vmware中的某个虚拟机死机且无法关机问题的快速解决办法

前情概要:公司某台服务器上采用的是vmware的方案进行部署的,在vmware中部署了多台虚拟机,某天其中一台虚拟机突然卡死(事后经检查是由于运行的python程序线程调用错误,导致CPU和内存占满,进而导致服务器卡死)且无法关机或其他
2023-08-19

Android中ImageView无法居中的问题解决方法

代码如下:[java] 代码如下:
2022-06-06

Android studio 项目手动在本地磁盘中删除module后,残留文件夹无法删除的问题解决方法

Android studio 项目手动在本地磁盘中删除module后,残留文件夹无法删除问题 如标题所述,本人在本地磁盘删除project中的module后(好吧,是我太菜了),仍然残留着一个文件夹,但是又无法右键之后又无法删除,(强迫症得
2022-06-06

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录