需求分析:
在套餐管理列表页面点击删除按钮,可以删除对应的套餐信息。也可以通过复选框选择多个套餐,点击批量删除按钮一次删除多个套餐。注意,对于状态为售卖中的套餐不能删除,需要先停售,然后再删除。
代码开发梳理过程:
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