SpringDataJpa大坑——一对多级联修改问题

前言

寒假接手一个项目,甲方提出了这样一个功能------需要一个商品有多张图片。可以进行滑动观看。这个需求很简单,前端只要做一个轮播图,后端只要涉及一个商品下有多组照片即可(一对多关系)。

项目后端选型

框架springboot 数据库框架springDataJpa

想要了解什么springDataJpa,可以看这篇文章

bug重现

甲方在后台图片进行图片拖动改变位置,点击进行修改按钮,该商品拖动改变位置的图片依旧没有发生变化。根据排查,前端发过来请求参数,确实改变了图片的位置。因此只能是后端背锅 啦!

可以给大家看看之前我写的前一版的代码(update方法)

java 复制代码
    @PostMapping("/updateModel")
    @ApiOperation(value = "更新型号", notes = "更新型号信息")
    public String updateModel(@RequestBody Model model) throws Exception {
        // 获取目标型号
        Model byModelId = modelService.findByModelId(model.getModelId());
        List<Image> targetImgs = byModelId.getImgs();
        if (byModelId == null) {
            throw new Exception("noModel");
        }
        if (targetImgs != null) {
            List<Image> imgs = model.getImgs();
            if(!CollectionUtils.isEmpty(imgs)) {
                List<String> url = imgs.stream().map(Image::getUrl).collect(Collectors.toList());
                for (Image image : model.getImgs()) {
                    url.add(image.getUrl());
                    imageService.addImage(image);
                }
                int waterMark = 1;
                // 改变了,要用原图进行添加水印,而不是用已经水印图进行再一次重复水印
                waterMark = createWaterMarkWithRaw(model.getModelName(), url);
                if (waterMark != 1) {
                    throw new Exception("添加水印失败");
                }
            }
        }
        // 更新保存到数据库
        modelService.updateModel(model);
        return "success";
    }

我在网上苦苦搜寻,都是关于对多端实体进行注解的添加,而我这个项目的多端就是商品下多个图片List< Image > imgs

java 复制代码
   @OneToMany(fetch=FetchType.EAGER,cascade=CascadeType.ALL,orphanRemoval = true)
   private List<Image> imgs;

cascade=CascadeType.ALL,orphanRemoval = true这两个说白了就是说进行级联操作,会对对应的子实体也会进行相应的改变(删除、插入等)

然后并没有什么卵用,我一直给干到一点中,弥留之际,我发现了问题的关键所在!

解决方案

因为jpa的机制,是可以通过注解@OneMany将实体创建表,也会创建关系表

在我这个项目就是Model 、Image和Model_img三张表。我在前面不断地测试插入,发现Model_img表没有发生改变 ,关联关系依旧是原来的"配对"。所以!说明咱们得update方法并没有进行修改Model_img表里所维护的数据。

那么我们只要手动干预model_img表中的关系数据,不就可以了吗。这样查出来就是修改后关系的数据了!

提交后的代码

java 复制代码
    @PostMapping("/updateModel")
    @ApiOperation(value = "更新型号", notes = "更新型号信息")
    public String updateModel(@RequestBody Model model) throws Exception {
        // 获取目标型号
        Model byModelId = modelService.findByModelId(model.getModelId());
        if (byModelId == null) {
            throw new Exception("noModel");
        }
        List<Image> newImags = new ArrayList<>();
        List<Image> imgs = model.getImgs();
        if(!CollectionUtils.isEmpty(imgs)) {
            List<String> url = imgs.stream().map(Image::getUrl).collect(Collectors.toList());
            for (Image image : model.getImgs()) {
                url.add(image.getUrl());
                imageService.addImage(image);
                Image newImage = new Image();
                newImage.setUrl(image.getUrl());
                newImags.add(newImage);
            }
            int waterMark = 1;
            // 改变了,要用原图进行添加水印,而不是用已经水印图进行再一次重复水印
            waterMark = createWaterMarkWithRaw(model.getModelName(), url);
            if (waterMark != 1) {
                throw new Exception("添加水印失败");
            }
        }
        // 清理原先数据
        model.getImgs().clear();
        // 添加修改位置的图片数据
        model.getImgs().addAll(newImags);
        modelService.updateModel(model);
        return "success";
    }

ps:多端实体也是需要进行添加相应的注解!即

java 复制代码
   @OneToMany(fetch=FetchType.EAGER,cascade=CascadeType.ALL,orphanRemoval = true)
   private List<Image> imgs;

到此,bug解决!时间终止为1点半!赚钱不易【叹气】

相关推荐
互联网全栈架构35 分钟前
遨游Spring AI:第一盘菜Hello World
java·人工智能·后端·spring
优秀的颜2 小时前
计算机基础知识(第五篇)
java·开发语言·分布式
BillKu2 小时前
Java严格模式withResolverStyle解析日期错误及解决方案
java
网安INF2 小时前
ElGamal加密算法:离散对数难题的安全基石
java·网络安全·密码学
AWS官方合作商3 小时前
在CSDN发布AWS Proton解决方案:实现云原生应用的标准化部署
java·云原生·aws
gadiaola4 小时前
【JVM】Java虚拟机(二)——垃圾回收
java·jvm
coderSong25686 小时前
Java高级 |【实验八】springboot 使用Websocket
java·spring boot·后端·websocket
Mr_Air_Boy7 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
豆沙沙包?8 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
年老体衰按不动键盘8 小时前
快速部署和启动Vue3项目
java·javascript·vue