首页 > 其他分享 >删除套餐

删除套餐

时间:2023-03-13 16:36:15浏览次数:27  
标签:queryWrapper LambdaQueryWrapper 删除 ids 套餐 setmeal

需求分析:

  在套餐管理列表页面点击删除按钮,可以删除对应的套餐信息。也可以通过复选框选择多个套餐,点击批量删除按钮一次删除多个套餐。注意,对于状态为售卖中的套餐不能删除,需要先停售,然后再删除。

代码开发梳理过程:

  1、在删除单个套餐时,页面发送ajax请求,根据套餐id删除对应套餐

  2、删除多个套餐时,页面发送ajax请求,根据提交的多个套餐id删除对应套餐

/**
     * 删除套餐,同时需要删除套餐和菜品的关联数据
     * @param ids
     */
    @Transactional
    @Override
    public void removeWithDish(List<Long> ids) {
        //select count(*) from setmeal where id in ids and status=1

        //查询套餐状态,确定是否可以删除
        LambdaQueryWrapper<Setmeal> queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.in(Setmeal::getId, ids);
        queryWrapper.eq(Setmeal::getStatus, 1);

        int count = this.count(queryWrapper);
        if(count > 0){
            //如果不能删除,抛出一个业务异常
            throw new CustomException("套餐正在售卖中,不能删除");
        }
        //如果可以删除,先删除套餐表中的数据----setmeal
        this.removeByIds(ids);
        //删除关系表中的数据---setmeal_dish
        //delete from setmeal_dish where setmeal_id in ids
        LambdaQueryWrapper<SetmealDish> queryWrapper1 = new LambdaQueryWrapper<>();
        queryWrapper1.in(SetmealDish::getSetmealId, ids);

        setmealDishService.remove(queryWrapper1);

    }
   /**
     * 删除套餐:删除一个或者批量删除
     * @param ids
     * @return
     */
    @DeleteMapping
    public R<String> delete(@RequestParam List<Long> ids){
//        log.info("ids:{}", ids);
        setmealService.removeWithDish(ids);
        return R.success("套餐数据删除成功");
    }

 

标签:queryWrapper,LambdaQueryWrapper,删除,ids,套餐,setmeal
From: https://www.cnblogs.com/fxzm/p/17209519.html

相关文章