苍穹外卖--在redis中缓存菜品数据,加快查询速度

修改用户端接口 DishController 的 list 方法,加入缓存处理逻辑:

@Autowired
    private RedisTemplate redisTemplate;
   @GetMapping("/list")
    @ApiOperation("根据分类id查询菜品")
    public Result<List<DishVO>> list(Long categoryId) {
   

        String key="dish_"+categoryId;
        List<DishVO> list1= (List<DishVO>) redisTemplate.opsForValue().get(key);
        if(list1 != null && list1.size() > 0){
   
            //如果存在,直接返回,无须查询数据库
            return Result.success(list1);
        }
        Dish dish = new Dish();
        dish.setCategoryId(categoryId);
        dish.setStatus(StatusConstant.ENABLE);//查询起售中的菜品

        List<DishVO> list = dishService.listWithFlavor(dish);
        //如果不存在,查询数据库,将查询到的数据放入redis中
        redisTemplate.opsForValue().set(key, list);
        return Result.success(list);
    }
}

调用清理缓存的方法,保证数据一致性:

1). 新增菜品优化

	/**
     * 新增菜品
     *
     * @param dishDTO
     * @return
     */
    @PostMapping
    @ApiOperation("新增菜品")
    public Result save(@RequestBody DishDTO dishDTO) {
   
        log.info("新增菜品:{}", dishDTO);
        dishService.saveWithFlavor(dishDTO);

        //清理缓存数据
        String key = "dish_" + dishDTO.getCategoryId();
        cleanCache(key);
        return Result.success();
    }

2). 菜品批量删除优化

	/**
     * 菜品批量删除
     *
     * @param ids
     * @return
     */
    @DeleteMapping
    @ApiOperation("菜品批量删除")
    public Result delete(@RequestParam List<Long> ids) {
   
        log.info("菜品批量删除:{}", ids);
        dishService.deleteBatch(ids);

        //将所有的菜品缓存数据清理掉,所有以dish_开头的key
        cleanCache("dish_*");

        return Result.success();
    }

3). 修改菜品优化

	/**
     * 修改菜品
     *
     * @param dishDTO
     * @return
     */
    @PutMapping
    @ApiOperation("修改菜品")
    public Result update(@RequestBody DishDTO dishDTO) {
   
        log.info("修改菜品:{}", dishDTO);
        dishService.updateWithFlavor(dishDTO);

        //将所有的菜品缓存数据清理掉,所有以dish_开头的key
        cleanCache("dish_*");

        return Result.success();
    }

4). 菜品起售停售优化

	/**
     * 菜品起售停售
     *
     * @param status
     * @param id
     * @return
     */
    @PostMapping("/status/{status}")
    @ApiOperation("菜品起售停售")
    public Result<String> startOrStop(@PathVariable Integer status, Long id) {
   
        dishService.startOrStop(status, id);

        //将所有的菜品缓存数据清理掉,所有以dish_开头的key
        cleanCache("dish_*");

        return Result.success();
    }

相关推荐

  1. 苍穹--redis缓存品数据,加快查询速度

    2023-12-06 15:46:03       51 阅读
  2. 苍穹总结

    2023-12-06 15:46:03       32 阅读
  3. 黑马苍穹

    2023-12-06 15:46:03       33 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-06 15:46:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-06 15:46:03       101 阅读
  3. 在Django里面运行非项目文件

    2023-12-06 15:46:03       82 阅读
  4. Python语言-面向对象

    2023-12-06 15:46:03       91 阅读

热门阅读

  1. 1091 Acute Stroke (三维搜索)

    2023-12-06 15:46:03       62 阅读
  2. HTML h1和h2的三点区别

    2023-12-06 15:46:03       56 阅读
  3. 如何在centos服务器上安装docker保姆教程

    2023-12-06 15:46:03       51 阅读
  4. 代码随想录二刷 |字符串 |右旋转字符串

    2023-12-06 15:46:03       62 阅读
  5. 深入理解Python包管理工具pip的基本命令和使用

    2023-12-06 15:46:03       43 阅读
  6. Linux ubuntu20.04 安装使用 Intel sgx

    2023-12-06 15:46:03       49 阅读
  7. [Ubuntu 18.04] RK3399搭建NFS服务实现共享目录

    2023-12-06 15:46:03       73 阅读
  8. Linux C语言 33-排序算法

    2023-12-06 15:46:03       57 阅读
  9. Vue学习笔记-activated和deactivated生命周期

    2023-12-06 15:46:03       61 阅读
  10. Unity - yield return相关用法

    2023-12-06 15:46:03       59 阅读
  11. 基于UDP网络聊天室OICQ

    2023-12-06 15:46:03       48 阅读
  12. 在macOS上使用Homebrew安装PHP的完整指南

    2023-12-06 15:46:03       48 阅读