瑞吉外卖实战学习--13、完善删除中的逻辑

2024-04-03 19:28

本文主要是介绍瑞吉外卖实战学习--13、完善删除中的逻辑,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

完善删除中的逻辑

  • 前言
  • 效果图
  • 逻辑介绍
  • 表结构
  • 根据mybatisPlus接口规范创建实体类和service和mapper文件
    • 1、实体类Dish和Setmeal
    • 2、Mapper接口DishMapper和SetealMapper
    • 3、Service接口DishService和setmealService
    • 4、Service实现类DishServiceImpl和setmealServicelmpl
  • 编写删除函数
    • 1、将创建刚才两个表的实体类
    • 2、获取表中categoryId和id相等的数据
    • 3、判断获取到的数据有几条
    • 4、如果大于0说明绑定了数据就抛出异常
    • 5、如果都不大于0就通过super调用通过id删除的方法
  • 自定义业务异常类
  • 在全局异常处理器中捕获异常

前言

本项目gitee位置:添加链接描述
之前实现了直接删除分类功能,并没有实现分类删除中的逻辑编写,本篇文章主要是针对删除逻辑来进行讲解,
本篇文章需要使用到Dish(菜品)和Setmeal(套餐)表,需要根据mybatisPlus规范创建实体类和接口类

效果图

在这里插入图片描述

逻辑介绍

检测分类删除的时候是否关联了别的菜品或者套餐

表结构

在这里插入图片描述
在这里插入图片描述

根据mybatisPlus接口规范创建实体类和service和mapper文件

1、实体类Dish和Setmeal

在这里插入图片描述

2、Mapper接口DishMapper和SetealMapper

在这里插入图片描述

3、Service接口DishService和setmealService

在这里插入图片描述

4、Service实现类DishServiceImpl和setmealServicelmpl

切记加@Service注解否则报错
在这里插入图片描述

编写删除函数

在这里插入图片描述

1、将创建刚才两个表的实体类

在这里插入图片描述

2、获取表中categoryId和id相等的数据

3、判断获取到的数据有几条

4、如果大于0说明绑定了数据就抛出异常

5、如果都不大于0就通过super调用通过id删除的方法

package com.example.ruiji_demo.service.impl;import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.example.ruiji_demo.common.CustomException;
import com.example.ruiji_demo.entity.Category;
import com.example.ruiji_demo.entity.Dish;
import com.example.ruiji_demo.entity.Setmeal;
import com.example.ruiji_demo.mapper.CategoryMapper;
import com.example.ruiji_demo.service.CategoryService;
import com.example.ruiji_demo.service.DishService;
import com.example.ruiji_demo.service.SetmealService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;/*** @author jitwxs* @date 2024年04月01日 21:44*/
@Service
public class CategoryServiceImpl extends ServiceImpl<CategoryMapper, Category> implements CategoryService {@Autowiredprivate DishService dishService;@Autowiredprivate SetmealService setmealService;/*** 根据id删除分类,删除之前进行判断* @param id*/@Overridepublic void remove(Long id){//检测分类删除的时候是否关联了别的菜品或者套餐//        创建菜品的实例LambdaQueryWrapper<Dish> dishLambdaQueryWrapper = new LambdaQueryWrapper<>();
//        获取表中categoryId和id相等的数据dishLambdaQueryWrapper.eq(Dish::getCategoryId,id);
//        判断获取到的数据有几条Long count1 = dishService.count(dishLambdaQueryWrapper);//        如果大于0说明关联了菜品if(count1>0){throw new CustomException("当前分类下关联了菜品,不能删除");}//        创建套餐的实例LambdaQueryWrapper<Setmeal> setmealLambdaQueryWrapper = new LambdaQueryWrapper<>();setmealLambdaQueryWrapper.eq(Setmeal::getCategoryId,id);Long count2 = setmealService.count(setmealLambdaQueryWrapper);if(count2>0){throw new CustomException("当前分类下关联了套餐,不能删除");}super.removeById(id);}}

自定义业务异常类

在这里插入图片描述

package com.example.ruiji_demo.common;/*** 自定义业务异常类* @author jitwxs* @date 2024年04月03日 16:52*/
public class CustomException extends RuntimeException {public CustomException(String message){super(message);}
}

在全局异常处理器中捕获异常

在这里插入图片描述

package com.example.ruiji_demo.common;import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;import java.sql.SQLIntegrityConstraintViolationException;/*** @author jitwxs* @date 2024年03月30日 22:24*/
@ControllerAdvice(annotations = {RestController.class, Controller.class})
@ResponseBody
@Slf4j
public class GlobalExceptionHandler {/*** 异常处理方法* @param ex* @return*/@ExceptionHandler(SQLIntegrityConstraintViolationException.class)public R<String> exceptionHandler(SQLIntegrityConstraintViolationException ex){log.error(ex.getMessage());
//        获取到是否是含有Duplicate entry的错误,如果是就提取出来名称,然后添加到报错信息if(ex.getMessage().contains("Duplicate entry")){String[] split = ex.getMessage().split(" ");String msg = split[2] + "已存在";return R.error(msg);}return R.error("添加失败");}@ExceptionHandler(CustomException.class)public R<String> exceptionHandler(CustomException ex){return R.error(ex.getMessage());}
}

这篇关于瑞吉外卖实战学习--13、完善删除中的逻辑的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

Java使用Tesseract-OCR实战教程

《Java使用Tesseract-OCR实战教程》本文介绍了如何在Java中使用Tesseract-OCR进行文本提取,包括Tesseract-OCR的安装、中文训练库的配置、依赖库的引入以及具体的代... 目录Java使用Tesseract-OCRTesseract-OCR安装配置中文训练库引入依赖代码实

shell脚本自动删除30天以前的文件(最新推荐)

《shell脚本自动删除30天以前的文件(最新推荐)》该文章介绍了如何使用Shell脚本自动删除指定目录下30天以前的文件,并通过crontab设置定时任务,此外,还提供了如何使用Shell脚本删除E... 目录shell脚本自动删除30天以前的文件linux按照日期定时删除elasticsearch索引s

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程

《在Java中使用ModelMapper简化Shapefile属性转JavaBean实战过程》本文介绍了在Java中使用ModelMapper库简化Shapefile属性转JavaBean的过程,对比... 目录前言一、原始的处理办法1、使用Set方法来转换2、使用构造方法转换二、基于ModelMapper

Java实战之自助进行多张图片合成拼接

《Java实战之自助进行多张图片合成拼接》在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用,本文为大家详细介绍了如何使用Java实现多张图片合成拼接,需要的可以了解下... 目录前言一、图片合成需求描述二、图片合成设计与实现1、编程语言2、基础数据准备3、图片合成流程4、图片合成实现三、总结前

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

nginx-rtmp-module构建流媒体直播服务器实战指南

《nginx-rtmp-module构建流媒体直播服务器实战指南》本文主要介绍了nginx-rtmp-module构建流媒体直播服务器实战指南,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. RTMP协议介绍与应用RTMP协议的原理RTMP协议的应用RTMP与现代流媒体技术的关系2