新增菜品(图片上传下载,菜品分类功能,两表关联查询和返回)

 参考这里建包建表

 第一步:

 两种方式做该下拉列表:

 第一种:

/**
     * 菜品分类下拉列表
     * @param category
     * @return
     */
    @GetMapping("/list")
    public R<List<Category>> list(Category category){
        LambdaQueryWrapper<Category> eq = Wrappers.lambdaQuery(Category.class)
                .eq(Category::getType, category.getType()).orderByAsc(Category::getSort);

        List<Category> list = categoryService.list(eq);

        return R.success(list);
    }

第二种:

/**
     * 菜品分类下拉列表
     * @param type
     * @return
     */
    @GetMapping("/list")
    public R<List<Category>> list(int type){
        LambdaQueryWrapper<Category> eq = Wrappers.lambdaQuery(Category.class)
                .eq(Category::getType, type).orderByAsc(Category::getSort);

        List<Category> list = categoryService.list(eq);

        return R.success(list);
    }

第二步:两表关联怎么保存以及返回数据

红色框内 属于dish表的数据,红色框外属于dish_flavor表

 

 

@Data
public class DishDto extends Dish {

    private List<DishFlavor> flavors = new ArrayList<>();

    private String categoryName;

    private Integer copies;
}

public interface DishService extends IService<Dish> {

    //新增菜品,同时插入菜品对应的口味数据,需要操作两张表:dish、dish_flavor
    public void saveWithFlavor(DishDto dishDto);
}

 

@Service
public class DishServicelmpl extends ServiceImpl<DishMapper, Dish> implements DishService {

    @Autowired
    private DishFlavorService dishFlavorService;

    /**
     * 新增菜品,同时保存对应的口味数据
     * @param dishDto
     */
    @Override
    @Transactional
    public void saveWithFlavor(DishDto dishDto) {
        //保存菜品的基本信息到菜品表dish
        this.save(dishDto);

        //菜品id:两表的关联id
        Long dishId = dishDto.getId();

        //菜品口味
        List<DishFlavor> flavors = dishDto.getFlavors();
        flavors = flavors.stream().map((item) -> {
            item.setDishId(dishId);
            return item;
        }).collect(Collectors.toList()); //将map类型再转换为List类型

        //保存菜品口味数据到菜品口味表dish_flavor
        dishFlavorService.saveBatch(flavors);
    }
}

开启对@Transactional注解的扫描

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值