Java新增菜品与分页查询怎么实现

      一. 新增菜品

      1.1需求分析

      后台系统可以管理分类信息,分类菜品分类和套餐分类。当我们在后台系统添加菜品时需要选择一个菜品分类。

      当我们在后台系统中添加一个套餐时需要选择一个套餐分类,在移动端也会按照菜品分类和套餐分类来展示对应的菜品和套餐。

      同时,在后台系统的分类管理页面分别添加菜品分类与套餐分类:

      添加菜品分类

      添加套餐分类

      数据模型:

      涉及一张表Category表:

      表对应的数据JavaBean为Category.java

      Category.java

      package com.itheima.reggie.entity;
      import com.baomidou.mybatisplus.annotation.FieldFill;
      import com.baomidou.mybatisplus.annotation.IdType;
      import com.baomidou.mybatisplus.annotation.TableField;
      import com.baomidou.mybatisplus.annotation.TableId;
      import lombok.Data;
      import lombok.Getter;
      import lombok.Setter;
      import java.io.Serializable;
      import java.time.LocalDateTime;
      /**
       * 分类
       */
      @Data
      public class Category implements Serializable {
          private static final long serialVersionUID = 1L;
          private Long id;
          //类型 1 菜品分类 2 套餐分类
          private Integer type;
          //分类名称
          private String name;
          //顺序
          private Integer sort;
          //创建时间
          @TableField(fill = FieldFill.INSERT)
          private LocalDateTime createTime;
          //更新时间
          @TableField(fill = FieldFill.INSERT_UPDATE)
          private LocalDateTime updateTime;
          //创建人
          @TableField(fill = FieldFill.INSERT)
          private Long createUser;
          //修改人
          @TableField(fill = FieldFill.INSERT_UPDATE)
          private Long updateUser;
          //是否删除
          private Integer isDeleted;
      }

      具体架子参照前面的Employee员工实体的搭建。

      1.2代码开发

      新增菜品分类与套餐分类请求的服务地址与提交的JSON数据结构相同,服务端只需提供一个方法即可:

      API
      说明
      请求URL/category
      请求数据{
      "name": "川菜",
      "type": "1",
      "sort": "1"
      }
      代码

      在CategoryController.java中编写新增代码:

      package com.itheima.reggie.controller;
      import com.itheima.reggie.common.R;
      import com.itheima.reggie.entity.Category;
      import com.itheima.reggie.service.CategoryService;
      import lombok.extern.slf4j.Slf4j;
      import org.springframework.web.bind.annotation.PostMapping;
      import org.springframework.web.bind.annotation.RequestBody;
      import org.springframework.web.bind.annotation.RequestMapping;
      import org.springframework.web.bind.annotation.RestController;
      import javax.annotation.Resource;
      /**
       * @author jektong
       * @date 2022年05月06日 21:47
       */
      @RestController
      @Slf4j
      @RequestMapping("/category")
      public class CategoryController {
          @Resource
          private CategoryService categoryService;
          /**
           * 新增分类
           * @param category
           * @return
           */
          @PostMapping
          public R<String> save(@RequestBody Category category){
              log.info("category:{}",category);
              categoryService.save(category);
              return R.success("新增分类成功");
          }
      }

      二. 分类信息分页查询

      分页查询与之前的员工信息查询是一样的,直接上代码:

      @GetMapping("/page")
          public R<Page> page(int page, int pageSize){
              // 分页构造
              Page<Category> pageInfo = new Page<Category>(page,pageSize);
              // 查询并排序
              LambdaQueryWrapper<Category> queryWrapper = new LambdaQueryWrapper();
              queryWrapper.orderByAsc(Category::getSort);
              // 分页查询
              categoryService.page(pageInfo,queryWrapper);
              return R.success(pageInfo);
          }

      三. 删除分类

      3.1 需求分析

      在分类管理列表页面,可以对某个分类进行删除操作。需要注意的是当分类关联了菜品或者套餐时,此分类不允许删除。

      API

      说明
      请求URL/category?id=

      需用引入菜品与套餐两个实体:

      Dish.java:菜品实体

      package com.itheima.reggie.entity;
      import com.baomidou.mybatisplus.annotation.FieldFill;
      import com.baomidou.mybatisplus.annotation.IdType;
      import com.baomidou.mybatisplus.annotation.TableField;
      import com.baomidou.mybatisplus.annotation.TableId;
      import lombok.Data;
      import java.io.Serializable;
      import java.math.BigDecimal;
      import java.time.LocalDateTime;
      /**
       菜品
       */
      @Data
      public class Dish implements Serializable {
          private static final long serialVersionUID = 1L;
          private Long id;
          //菜品名称
          private String name;
          //菜品分类id
          private Long categoryId;
          //菜品价格
          private BigDecimal price;
          //商品码
          private String code;
          //图片
          private String image;
          //描述信息
          private String description;
          //0 停售 1 起售
          private Integer status;
          //顺序
          private Integer sort;
          @TableField(fill = FieldFill.INSERT)
          private LocalDateTime createTime;
          @TableField(fill = FieldFill.INSERT_UPDATE)
          private LocalDateTime updateTime;
          @TableField(fill = FieldFill.INSERT)
          private Long createUser;
          @TableField(fill = FieldFill.INSERT_UPDATE)
          private Long updateUser;
          //是否删除
          private Integer isDeleted;
      }

      Setmeal.java:套餐实体

      package com.itheima.reggie.entity;
      import com.baomidou.mybatisplus.annotation.FieldFill;
      import com.baomidou.mybatisplus.annotation.IdType;
      import com.baomidou.mybatisplus.annotation.TableField;
      import com.baomidou.mybatisplus.annotation.TableId;
      import lombok.Data;
      import java.io.Serializable;
      import java.math.BigDecimal;
      import java.time.LocalDateTime;
      /**
       * 套餐
       */
      @Data
      public class Setmeal implements Serializable {
          private static final long serialVersionUID = 1L;
          private Long id;
          //分类id
          private Long categoryId;
          //套餐名称
          private String name;
          //套餐价格
          private BigDecimal price;
          //状态 0:停用 1:启用
          private Integer status;
          //编码
          private String code;
          //描述信息
          private String description;
          //图片
          private String image;
          @TableField(fill = FieldFill.INSERT)
          private LocalDateTime createTime;
          @TableField(fill = FieldFill.INSERT_UPDATE)
          private LocalDateTime updateTime;
          @TableField(fill = FieldFill.INSERT)
          private Long createUser;
          @TableField(fill = FieldFill.INSERT_UPDATE)
          private Long updateUser;
          //是否删除
          private Integer isDeleted;
      }

      3.2 核心代码

      CategoryServiceImpl.java

      package com.itheima.reggie.service.impl;
      import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
      import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
      import com.itheima.reggie.common.CustomException;
      import com.itheima.reggie.entity.Category;
      import com.itheima.reggie.entity.Dish;
      import com.itheima.reggie.entity.Setmeal;
      import com.itheima.reggie.mapper.CategoryMapper;
      import com.itheima.reggie.service.CategoryService;
      import com.itheima.reggie.service.DishService;
      import com.itheima.reggie.service.SetmealService;
      import org.springframework.stereotype.Service;
      import javax.annotation.Resource;
      /**
       * @author jektong
       * @date 2022年05月06日 21:44
       */
      @Service
      public class CategoryServiceImpl extends ServiceImpl<CategoryMapper, Category> implements CategoryService {
          @Resource
          private DishService dishService;
          @Resource
          private SetmealService setmealService;
          /**
           * 根据ID删除分类,分类之前需要判断
           * @param id
           */
          @Override
          public void remove(Long id) {
              LambdaQueryWrapper<Dish> dishLambdaQueryWrapper =  new LambdaQueryWrapper<>();
              // 查询当前分类是否关联了菜品,若关联菜品,抛出异常
              dishLambdaQueryWrapper.eq(Dish::getCategoryId,id);
              int count = dishService.count(dishLambdaQueryWrapper);
              if(count > 0){
                  // 已经关联菜品,抛出异常
                  throw new CustomException("当前分类已关联菜品,不可删除");
              }
              // 查询当前分类是否关联了套餐,若关联菜品,抛出异常
              LambdaQueryWrapper<Setmeal> setmealLambdaQueryWrapper =  new LambdaQueryWrapper<>();
              setmealLambdaQueryWrapper.eq(Setmeal::getCategoryId,id);
              int count1 = setmealService.count(setmealLambdaQueryWrapper);
              if(count>0){
                  // 已经关联套餐,抛出异常
                  throw new CustomException("当前分类已关联套餐,不可删除");
              }
              // 正常删除分类
              super.removeById(id);
          }
      }

      前面自定义异常类中加入:

      /**
           * 异常处理方法
           * @param customException
           * @return
           */
          @ExceptionHandler(CustomException.class)
          public R<String> exceptionHandler(CustomException customException){
              log.error(customException.getMessage());
              return R.error(customException.getMessage());
          }

      CustomException.java

      package com.itheima.reggie.common;
      /**
       * @author jektong
       * @date 2022年05月10日 22:26
       */
      public class CustomException extends RuntimeException{
          public CustomException(String msg){
              super(msg);
          }
      }

      四. 修改分类

      修改分类很简单,根据分类ID修改就可以了,代码如下:

      @PutMapping
      public R<String> update(@RequestBody Category category){
        log.info("修改分类信息{}" + category);
        categoryService.updateById(category);
        return R.success("分类修改成功");
      }

      以上就是Java新增菜品与分页查询怎么实现的详细内容,更多请关注其它相关文章!