项目实战-多子集循环嵌套 更新时的处理逻辑

2024-08-30 14:36

本文主要是介绍项目实战-多子集循环嵌套 更新时的处理逻辑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目实战 多子集循环嵌套 更新时的处理逻辑

商品多子集循环嵌套 更新场景时的处理逻辑

场景背景:业务中,套餐下面有多个商品,每个商-品又有多个sku。目前分为套餐表、商品表、sku表,现在更新套餐时 商品和sku都有可能出现增删改的情况,代码里如何区分是新增 修改 和删除呢

假设我们是Spring Boot 项目,在处理套餐、商品、SKU 的增删改操作时,可以采用以下方案来区分并处理新增、修改和删除操作。

一、前端传递完整的数据结构

首先,前端应该将更新后的套餐数据完整地传递给后端,包括所有商品和 SKU 的详细信息。数据结构可能如下:

{"packageId": 1,"packageName": "套餐A","items": [{"itemId": 1,  // 如果为null,则是新增"itemName": "商品 A","skus": [{"skuId": 1,  // 如果为null,则是新增"skuName": "SKU A","price": 100},{"skuId": 2,"skuName": "SKU B","price": 200}]},{"itemId": null,  // 新增商品"itemName": "商品 B","skus": [{"skuId": null,  // 新增 SKU"skuName": "SKU C","price": 150}]}]
}

二、 后端处理逻辑

在后端,可以根据传入数据的 itemIdskuId 来区分新增、修改和删除。

2.1 新增操作
  • 如果 itemIdskuIdnull,表示这是一个新增的记录。
2.2 修改操作
  • 如果 itemIdskuId 都存在,并且与数据库中的记录匹配,则表示这是一个修改操作。
2.3 删除操作
  • 可以通过比较数据库中的数据和前端传递的数据,找出哪些商品和 SKU 在前端数据中没有出现,这些就是需要删除的项。

三. 代码实现示例

@Service
public class PackageService {@Autowiredprivate PackageRepository packageRepository;@Autowiredprivate ItemRepository itemRepository;@Autowiredprivate SkuRepository skuRepository;@Transactionalpublic void updatePackage(PackageDTO packageDTO) {// 1. 更新套餐信息PackageEntity packageEntity = packageRepository.findById(packageDTO.getPackageId()).orElseThrow(() -> new ResourceNotFoundException("该套餐不存在"+packageDTO.getPackageId()));packageEntity.setName(packageDTO.getPackageName());packageRepository.save(packageEntity);// 2. 更新商品信息List<ItemEntity> existingItems = itemRepository.findByPackageId(packageDTO.getPackageId());for (ItemDTO itemDTO : packageDTO.getItems()) {if (itemDTO.getItemId() == null) {// 新增商品ItemEntity newItem = new ItemEntity();newItem.setPackageId(packageEntity.getId());newItem.setName(itemDTO.getItemName());itemRepository.save(newItem);updateSkus(newItem.getId(), itemDTO.getSkus());} else {// 修改商品ItemEntity existingItem = itemRepository.findById(itemDTO.getItemId()).orElseThrow(() -> new ResourceNotFoundException("该商品不存在"+itemDTO.getItemId()));existingItem.setName(itemDTO.getItemName());itemRepository.save(existingItem);updateSkus(existingItem.getId(), itemDTO.getSkus());existingItems.remove(existingItem);}}// 删除商品for (ItemEntity itemToDelete : existingItems) {skuRepository.deleteByItemId(itemToDelete.getId());itemRepository.delete(itemToDelete);}}private void updateSkus(Long itemId, List<SkuDTO> skus) {List<SkuEntity> existingSkus = skuRepository.findByItemId(itemId);for (SkuDTO skuDTO : skus) {if (skuDTO.getSkuId() == null) {// 新增 SKUSkuEntity newSku = new SkuEntity();newSku.setItemId(itemId);newSku.setName(skuDTO.getSkuName());newSku.setPrice(skuDTO.getPrice());skuRepository.save(newSku);} else {// 修改 SKUSkuEntity existingSku = skuRepository.findById(skuDTO.getSkuId()).orElseThrow(() -> new ResourceNotFoundException("该SKU规格不存在"+skuDTO.getSkuId()));existingSku.setName(skuDTO.getSkuName());existingSku.setPrice(skuDTO.getPrice());skuRepository.save(existingSku);existingSkus.remove(existingSku);}}// 删除 SKUfor (SkuEntity skuToDelete : existingSkus) {skuRepository.delete(skuToDelete);}}
}

四. 总结

  • 新增: 通过判断 id 是否为 null 来判断是否为新增操作。
  • 修改: 如果 id 存在且匹配,视为修改操作。
  • 删除: 通过比较现有数据库记录与传入数据来判断需要删除的项。

这种方案能够有效处理复杂的增删改操作,确保数据的一致性。当然也可以结合算法进行处理,欢迎评论区讨论。
为了接口性能以及接口响应时间,减少对数据库的读写次数,可以考虑进行批量更新、批量新增处理。具体的可以根据实际业务场景进行分析,也欢迎一起交流讨论。关注我,为程序员职业生涯储能!!

这篇关于项目实战-多子集循环嵌套 更新时的处理逻辑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121095

相关文章

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer