苍穹外卖--菜品管理-修改功能实现

This commit is contained in:
2025-11-11 15:24:13 +08:00
parent 85cd67f345
commit cbb596cf02
7 changed files with 106 additions and 0 deletions

View File

@@ -5,6 +5,7 @@ import com.sky.dto.DishPageQueryDTO;
import com.sky.result.PageResult;
import com.sky.result.Result;
import com.sky.service.DishService;
import com.sky.vo.DishVO;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
@@ -52,4 +53,20 @@ public class DishController {
dishService.deleteBath(ids);
return Result.success();
}
@GetMapping("/{id}")
@ApiOperation("根据id查询菜品")
public Result<DishVO> getById(@PathVariable Long id){ //@RequestParam能够使用springmvc框架对1,2,3 参数进行切割
log.info("根据id查询菜品{}",id);
DishVO dishVO = dishService.getByIdWithFlavor(id);
return Result.success(dishVO);
}
@PutMapping
@ApiOperation("修改菜品")
public Result getById(@RequestBody DishDTO dishDTO){ //@RequestParam能够使用springmvc框架对1,2,3 参数进行切割
log.info("修改菜品:{}",dishDTO);
dishService.updateWithFlavor(dishDTO);
return Result.success();
}
}

View File

@@ -2,6 +2,7 @@ package com.sky.mapper;
import com.sky.entity.DishFlavor;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import java.util.List;
@@ -18,4 +19,12 @@ public interface DishFlavorMapper {
* @param ids
*/
void deleteBath(List<Long> ids);
/**
* 根据菜品id查询对应口味数据
* @param dishId
* @return
*/
@Select("select * from dish_flavor where dish_id = #{dishId}")
List<DishFlavor> getByDishId(Long dishId);
}

View File

@@ -50,4 +50,11 @@ public interface DishMapper {
* @param ids
*/
void deleteBath(List<Long> ids);
/**
* 更新菜品表
* @param dish
*/
@AutoFill(OperationType.UPDATE)
void update(Dish dish);
}

View File

@@ -3,6 +3,7 @@ package com.sky.service;
import com.sky.dto.DishDTO;
import com.sky.dto.DishPageQueryDTO;
import com.sky.result.PageResult;
import com.sky.vo.DishVO;
import java.util.List;
@@ -24,4 +25,17 @@ public interface DishService {
* @param ids
*/
void deleteBath(List<Long> ids);
/**
* 根据id查询菜品
* @param id
* @return
*/
DishVO getByIdWithFlavor(Long id);
/**
* 修改菜品
* @param dishDTO
*/
void updateWithFlavor(DishDTO dishDTO);
}

View File

@@ -20,6 +20,7 @@ import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.Arrays;
import java.util.List;
@Service
@@ -97,4 +98,44 @@ public class DishServiceImpl implements DishService {
dishMapper.deleteBath(ids);
dishFlavorMapper.deleteBath(ids);
}
/**
* 根据id查询菜品
* @param id
* @return
*/
@Override
public DishVO getByIdWithFlavor(Long id) {
//1.查询2张表菜品表和口味表
Dish dish = dishMapper.getById(id);
List<DishFlavor> flavors = dishFlavorMapper.getByDishId(id);
//对象属性拷贝
DishVO dishVO = new DishVO();
BeanUtils.copyProperties(dish,dishVO);
dishVO.setFlavors(flavors);
return dishVO;
}
/**
* 修改菜品
* @param dishDTO
*/
@Override
public void updateWithFlavor(DishDTO dishDTO) {
//1.修改的表Dish Dish_flavor
Dish dish = new Dish();
BeanUtils.copyProperties(dishDTO,dish);
//2.修改菜品表
dishMapper.update(dish);
//3.修改口味表:先执行删除对应菜品的全部口味,再重新插入
dishFlavorMapper.deleteBath(Arrays.asList(dishDTO.getId()));
List<DishFlavor> flavors = dishDTO.getFlavors();
//确保口味的菜品id必须有
flavors.forEach(dishFlavor -> dishFlavor.setDishId(dishDTO.getId()));
if (flavors != null && flavors.size() > 0) {
dishFlavorMapper.insertBath(flavors);
}
}
}