6--苍穹外卖-SpringBoot项目中菜品管理 详解(二)

news/2024/9/29 15:56:09/

目录

菜品分页查询

需求分析和设计

代码开发

设计DTO类

设计VO类

Controller层

Service层接口

Service层实现类

Mapper层

功能测试

删除菜品

需求设计和分析

代码开发

Controller层

Service层接口

Service层实现类

Mapper层

功能测试

修改菜品

需求分析和设计

代码开发

根据id查询菜品实现

Controller层

Service层接口

Service层实现类

Mapper层

修改菜品实现

Controller层

Service层接口

Service层实现类

Mapper层

功能测试


  
1--苍穹外卖-SpringBoot项目介绍及环境搭建 详解-CSDN博客

2--苍穹外卖-SpringBoot项目中员工管理 详解(一)-CSDN博客

3--苍穹外卖-SpringBoot项目中员工管理 详解(二)-CSDN博客

4--苍穹外码-SpringBoot项目中分类管理 详解-CSDN博客

5--苍穹外卖-SpringBoot项目中菜品管理 详解(一)-CSDN博客

6--苍穹外卖-SpringBoot项目中菜品管理 详解(二)-CSDN博客

7--苍穹外卖-SpringBoot项目中套餐管理 详解(一)-CSDN博客

8--苍穹外卖-SpringBoot项目中套餐管理 详解(二)-CSDN博客

9--苍穹外卖-SpringBoot项目中Redis的介绍及其使用实例 详解-CSDN博客

菜品分页查询

需求分析和设计

业务规则:

  • 根据页码展示菜品信息

  • 每页展示10条数据

  • 分页查询时可以根据需要输入菜品名称、菜品分类、菜品状态进行查询

代码开发

设计DTO类

根据菜品分页查询接口定义设计对应的DTO:

在sky-pojo模块中

java">package com.sky.dto;import lombok.Data;import java.io.Serializable;@Data
public class DishPageQueryDTO implements Serializable {private int page;private int pageSize;private String name;//分类idprivate Integer categoryId;//状态 0表示禁用 1表示启用private Integer status;}
设计VO类

根据菜品分页查询接口定义设计对应的VO:(在返回的数据中categoryName属于另外一个文件中,需要使用VO转换属性为json,方便前端展示)

在sky-pojo模块中

java">package com.sky.vo;import com.sky.entity.DishFlavor;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class DishVO implements Serializable {private Long id;//菜品名称private String name;//菜品分类idprivate Long categoryId;//菜品价格private BigDecimal price;//图片private String image;//描述信息private String description;//0 停售 1 起售private Integer status;//更新时间private LocalDateTime updateTime;//分类名称private String categoryName;//菜品关联的口味private List<DishFlavor> flavors = new ArrayList<>();//private Integer copies;
}
Controller层

根据接口定义创建DishController的page分页查询方法:

java">//菜品分页查询@GetMapping("/page")@ApiOperation("菜品分页查询")public Result<PageResult> page(DishPageQueryDTO dishPageQueryDTO){log.info("菜品分页查询:{}",dishPageQueryDTO);PageResult pageResult=dishService.pageQuery(dishPageQueryDTO);return Result.success(pageResult);}
Service层接口

在 DishService 中扩展分页查询方法:

java"> //菜品分页查询PageResult pageQuery(DishPageQueryDTO dishPageQueryDTO);
Service层实现类

在 DishServiceImpl 中实现分页查询方法:

java"> //菜品分页查询@Overridepublic PageResult pageQuery(DishPageQueryDTO dishPageQueryDTO) {PageHelper.startPage(dishPageQueryDTO.getPage(),dishPageQueryDTO.getPageSize());Page<DishVO> page= dishMapper.pageQuery(dishPageQueryDTO);return new PageResult(page.getTotal(),page.getResult());}
Mapper层

在 DishMapper 接口中声明 pageQuery 方法:

java"> //菜品分页查询Page<DishVO> pageQuery(DishPageQueryDTO dishPageQueryDTO);

在 DishMapper.xml 中编写SQL:

java"> <select id="pageQuery" resultType="com.sky.vo.DishVO">select d.* ,c.name as categoryName from dish d left outer join category c on d.category_id=c.id<where><if test="name!=null">and d.name like concat('%',#{name},'%')</if><if test="categoryId!=null">and d.category_id=#{categoryId}</if><if test="status!=null">and d.status=#{status}</if></where>order by d.create_time desc</select>

功能测试

删除菜品

需求设计和分析

业务规则:

  • 可以一次删除一个菜品,也可以批量删除菜品

  • 起售中的菜品不能删除

  • 被套餐关联的菜品不能删除

  • 删除菜品后,关联的口味数据也需要删除掉

代码开发

Controller层

根据删除菜品的接口定义在DishController中创建方法:

java">//菜品批量删除@DeleteMapping@ApiOperation("菜品批量删除")public Result<String> delete(@RequestParam List<Long> ids){//@RequestParam注解使用mvc框架,可以获取到参数1,2,3中的变量值log.info("菜品批量删除,{}",ids);dishService.deleteBatch(ids);return Result.success();}
Service层接口

在DishService接口中声明deleteBatch方法:

java">  //菜品批量删除void deleteBatch(List<Long> ids);
Service层实现类

在DishServiceImpl中实现deleteBatch方法:

java">  //菜品批量删除@Transactional//事务public void deleteBatch(List<Long> ids) {//判断当前菜品是否能够删除---是否存在起售中的菜品for (Long id : ids) {//根据主键查询菜品Dish dish=dishMapper.getById(id);//查询是否起售if (Objects.equals(dish.getStatus(), StatusConstant.ENABLE)){//当前菜品处于起售中,不能删除throw new DeletionNotAllowedException(MessageConstant.DISH_ON_SALE);}}//判断当前菜品是否能够删除---是否被套餐关联了List<Long> setmealIds=setmealDishMapper.getSetmealIdsByDishIds(ids);if (setmealIds!=null&& !setmealIds.isEmpty()){//当前菜品被套餐关联了,不能删除throw new DeletionNotAllowedException(MessageConstant.DISH_BE_RELATED_BY_SETMEAL);}//删除菜品表中的菜品数据for (Long id : ids) {dishMapper.deleteById(id);//删除菜品关联的口味数据dishFlavorMapper.deleteByDishId(id);}
Mapper层

在DishMapper中声明getById方法,并配置SQL:

java"> //根据主键查询菜品@Select("select *from dish where id=#{id}")Dish getById(Long id);

创建SetmealDishMapper,声明getSetmealIdsByDishIds方法,并在xml文件中编写SQL:

java">package com.sky.mapper;import org.apache.ibatis.annotations.Mapper;import java.util.List;@Mapper
public interface SetmealDishMapper {//根据菜品id查询对应的套餐idList<Long> getSetmealIdsByDishIds(List<Long> dishIds);}

SetmealDishMapper.xml

java"><?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.sky.mapper.SetmealDishMapper"><select id="getSetmealIdsByDishIds" resultType="java.lang.Long">select setmeal_id from setmeal_dish where dish_id in<foreach collection="dishIds" item="dishId" separator="," open="(" close=")">#{dishId}</foreach></select>
</mapper>

在DishMapper.java中声明deleteById方法并配置SQL:

java">    //根据主键删除菜品数据@Delete("delete from dish where id=#{id}")void deleteById(Long id);

在DishFlavorMapper中声明deleteByDishId方法并配置SQL:

java"> //根据菜品id删除对应的口味数据@Delete("delete from dish_flavor where dish_id=#{dishId}")void deleteByDishId(Long dishId);

 性能优化

在DishServiceImpl中,删除菜品是一条一条传送执行的,大大降低了执行效率,原代码如下:

java">//删除菜品表中的菜品数据for (Long id : ids) {dishMapper.deleteById(id);//删除菜品关联的口味数据dishFlavorMapper.deleteByDishId(id);}

为了提高性能,进行修改,使用动态sql执行删除操作

java"> //根据菜品id集合批量删除菜品数据//sql:delete from dish where id in(?,?,?)dishMapper.deleteByIds(ids);//根据菜品id集合批量删除关联的口味数据//sql:delete from dish_flavor where dish_id in(?,?,?)dishMapper.deleteByDishIds(ids);

在DishMapper中

java"> //根据菜品id集合批量删除菜品void deleteByIds(List<Long> ids);//根据菜品id集合批量删除关联的口味数据void deleteByDishIds(List<Long> dishId);

在DishMapper.xml中

java"> <delete id="deleteByIds">delete from dish where id in<foreach collection="ids" open="(" separator="," close=")" item="id">#{id}</foreach></delete><delete id="deleteByDishIds">delete from dish_flavor where dish_id in<foreach collection="dishIds" open="(" close=")" separator="," item="dishId">#{dishId}</foreach></delete>

功能测试

进行前后端联调,删除成功

修改菜品

需求分析和设计

接口:

  • 根据id查询菜品

  • 根据类型查询分类(已实现)

  • 文件上传(已实现)

  • 修改菜品

代码开发

根据id查询菜品实现

Controller层

根据id查询菜品的接口定义在DishController中创建方法:

java"> //根据id查询菜品@GetMapping("/{id}")@ApiOperation("根据id查询菜品")public  Result<DishVO> getById(@PathVariable Long id){log.info("根据id查询菜品:{}",id);DishVO dishVO=dishService.getByIdWithFlavor(id);return  Result.success(dishVO);}
Service层接口

在DishService接口中声明getByIdWithFlavor方法:

java"> //根据id查询菜品和对应的口味数据DishVO getByIdWithFlavor(Long id);
Service层实现类

在DishServiceImpl中实现getByIdWithFlavor方法:

java">//根据id查询菜品和对应的口味数据@Overridepublic DishVO getByIdWithFlavor(Long id) {//根据id查询菜品数据Dish dish=dishMapper.getById(id);//根据菜品id查询口味数据List<DishFlavor> dishFlavors=dishFlavorMapper.getByDishId(id);//将查询到的数据封装到VODishVO dishVO = new DishVO();BeanUtils.copyProperties(dish,dishVO);dishVO.setFlavors(dishFlavors);return dishVO;}
Mapper层

在DishFlavorMapper中声明getByDishId方法,并配置SQL:

java">//根据id查询对应的口味数据@Select("select *from dish_flavor where dish_id=#{dishId}")List<DishFlavor> getByDishId(Long dishId);

修改菜品实现

Controller层

根据修改菜品的接口定义在DishController中创建方法:

java"> //修改菜品@PutMapping@ApiOperation("修改菜品")public Result<String> update(@RequestBody DishDTO dishDTO){log.info("修改菜品:{}",dishDTO);dishService.updateWithFlavor(dishDTO);return Result.success();}
Service层接口

在DishService接口中声明updateWithFlavor方法:

java"> //根据id修改菜品基本信息和对应的口味数据void updateWithFlavor(DishDTO dishDTO);
Service层实现类

在DishServiceImpl中实现updateWithFlavor方法:

java">//根据id修改菜品基本信息和对应的口味信息@Overridepublic void updateWithFlavor(DishDTO dishDTO) {Dish dish = new Dish();BeanUtils.copyProperties(dishDTO,dish);//修改菜品表基本信息dishMapper.update(dish);//删除原有的口味数据dishFlavorMapper.deleteByDishId(dishDTO.getId());//重新插入口味数据List<DishFlavor> flavors = dishDTO.getFlavors();if (flavors!=null&& !flavors.isEmpty()){flavors.forEach(dishFlavor -> {dishFlavor.setDishId(dishDTO.getId());});//向口味表插入n条数据dishFlavorMapper.insertBatch(flavors);}}
Mapper层

在DishMapper中,声明update方法:

java"> //根据id动态修改菜品数据@AutoFill(value = OperationType.UPDATE)void update(Dish dish);

并在DishMapper.xml文件中编写SQL:

java"> <update id="update">update dish<set><if test="name!=null">name=#{name},</if><if test="categoryId!=null">category_id=#{categoryId},</if><if test="price!=null">price=#{price},</if><if test="image!=null">image=#{image},</if><if test="description!=null">description=#{description},</if><if test="status!=null">status=#{status},</if><if test="updateTime!=null">update_time=#{updateTime},</if><if test="updateUser!=null">update_user=#{updateUser},</if></set>where id=#{id}</update>

功能测试


http://www.ppmy.cn/news/1531990.html

相关文章

Linux安装go-fastdfs

安装 mkdir /home/go-fastdfs wget -P /home/go-fastdfs https://github.com/sjqzhang/go-fastdfs/releases/download/v1.4.5/fileserver chmod x /home/go-fastdfs/fileserver cd /home/go-fastdfs nohup ./fileserver server &由于fileserver下载速度巨慢&#xff0c;此…

17年数据结构考研真题解析

第一题&#xff1a; 解析&#xff1a; 我们说递归要找出口&#xff0c;这道题的出口是sum<n&#xff0c;经过观察可以得知&#xff1a;sum123。。。k 设第k次循环跳出&#xff0c;则有sum123。。。k<n k<,很显然答案选B 第二题&#xff1a; 解析&#xff1a; 第一句&a…

C++ STL容器(三) —— 迭代器底层剖析

本篇聚焦于STL中的迭代器&#xff0c;同样基于MSVC源码。 文章目录 迭代器模式应用场景实现方式优缺点 UML类图代码解析list 迭代器const 迭代器非 const 迭代器 vector 迭代器const 迭代器非const迭代器 反向迭代器 迭代器失效参考资料 迭代器模式 首先迭代器模式是设计模式中…

如何理解MYSQL的体系结构

1.MySQL服务器进程mysqld由哪三层组成&#xff0c;从各自所实现的功能角度分别加以说明。 连接层 SQL层 存储层 连接层&#xff1a;通讯协议&#xff0c;TCP/IP本地远程通讯、Socket本地通讯&#xff08;Linux&#xff09;;为…

窗口函数用法

窗口函数&#xff08;Window Functions&#xff09;是SQL中一种强大的工具&#xff0c;允许你在数据集的特定“窗口”或“分区”内执行计算&#xff0c;而不需要对数据进行分组汇总&#xff08;即不会减少返回的行数&#xff09;。这些计算可以包括行号、移动平均、排名等。窗口…

24年Novartis诺华制药社招入职SHL测评:综合能力、性格问卷、动机问卷高分攻略

尊敬的求职者&#xff0c;若您渴望在医药行业的领军企业——诺华制药——开启您的职业生涯&#xff0c;深入了解其社招与校招测评流程至关重要。以下是对诺华SHL测评题型的全面解读&#xff0c;助您在招聘季脱颖而出。 测评构成 诺华的招聘测评由以下三个部分组成&#xff1a…

克里金插值算法文件

由于作者时间发布的比较久&#xff0c;导致一些cesium api和当前版本api不同&#xff0c;故改之&#xff1a; 文件名&#xff1a;kriging.js /*!* author: [object Object]* sakitam-gis/kriging v0.1.0* build-time: 2019-7-6 20:41* LICENSE: MIT* (c) 2019-2019 https://gi…

grafana加载缓慢解决方案

背景 目前随着数据和图表的逐渐增多&#xff0c;Grafana 页面加载速度明显变慢&#xff0c;严重影响了用户体验&#xff0c;几次都有骂娘的冲动.&#xff0c;因此我们需要对 Grafana 进行优化&#xff0c;以提升加载性能。 对于速度优化&#xff0c;我们可以从以下方面进行入…