苍穹外卖项目(黑马)学习笔记DAY7

目录

缓存菜品功能

 清除缓存功能

缓存套餐功能        

Spring Cache

 添加购物车功能

查看购物车功能

清空购物车功能

删除单个菜品功能(作业)


缓存菜品功能

        如果大量用户访问,每次访问菜单都需要查询数据,服务器压力较大,因此使用Redis缓存。

        实现思路:查询菜品是先判断是否有缓存,有则读取缓存,无则查询数据库后保存缓存,以供下一次查询。

        缓存逻辑:每个分类下的菜品保存一份缓存数据。数据库中菜品数据变更时清理缓存数据。

    @GetMapping("/list")
    @ApiOperation("根据分类id查询菜品")
    public Result<List<DishVO>> list(Long categoryId) {
        //构造reedis中的key
        String key="dish_"+categoryId;
        ValueOperations valueOperations = redisTemplate.opsForValue();
        //查询redis中是否存在菜品数据 放进去是什么类型,取回来就是什么类型
        List<DishVO> list = (List<DishVO>) valueOperations.get(key);
        if(list!=null &&list.size()>0){
            return Result.success(list);
        }
        //如果没有则查询数据口,并保存在redis中
        Dish dish = new Dish();
        dish.setCategoryId(categoryId);
        dish.setStatus(StatusConstant.ENABLE);//查询起售中的菜品

        list = dishService.listWithFlavor(dish);
        valueOperations.set(key,list);
        return Result.success(list);
    }

 清除缓存功能

        为了保证数据的一致性,即用户看到的和数据库看到的数据是相同的,在数据库更新的时候需要清楚缓存数据。

        新增、修改、删除、起售停售菜品都需要清楚缓存。

        String key="dish_"+dishDTO.getCategoryId();
        cleanCache(key);
        //删除或更新时直接把所有缓存数据删除 不需要精准删除缓存 可以简便操作
    private void cleanCache(String pattern){
        Set keys = redisTemplate.keys(pattern);
        redisTemplate.delete(keys);

    }

缓存套餐功能        

  • Spring Cache

        Spring Cache是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。底层可以使用EHCache、Caffeine、Redis实现缓存。 

        注解一般放在Controller的方法上,@CachePut 注解一般有两个参数,第一个时存储的名称,第二个时名称后边的key,使用SpEL动态的计算key。其余的注解也都是这两个参数。在用户端的查询操作需要使用@Cacheable,服务器端的增删改都使用@CacheEvict

 添加购物车功能

        用什么方法请求?传入什么参数?返回什么数据?

        使用Post的方式请求。需要传入口味和菜品id或套餐id。没有额外的数据需要返回。

        添加购物车的逻辑时,添加前先判断数据库中有无相同菜品,如果有则将其数量字段更新为1加一即可,如果没有则直接插入数据。插入数据的时候先判断是菜品还是套餐,因为需要给购物车实体对象赋值后进行插入。判断的方法是直接获取dishId和setmealId,判断其是否为空。

            Long dishId = shoppingCart.getDishId();
            Long setmealId = shoppingCart.getSetmealId();
            if(dishId!=null){


            }else{
                



            }

查看购物车功能

        用什么方法请求?传入什么参数?返回什么数据?

        使用get的方式请求。由于查询的是所有购物车,因此不需要传入数据。返回一个集合里面包含购物车实体对象。

清空购物车功能

        用什么方法请求?传入什么参数?返回什么数据?

        使用get的方式请求。不需要传入数据。也没有额外的数据需要返回。

删除单个菜品功能(作业)

        用什么方法请求?传入什么参数?返回什么数据?

        使用post方式请求。需要传入shoppingCartDTO。无额外返回的数据。

    //controller
    @PostMapping("/sub")
    @ApiOperation("购物车删除当个商品")
    public Result deleteById(@RequestBody ShoppingCartDTO shoppingCartDTO){
        shoppingCartService.delete(shoppingCartDTO);
        return Result.success();
    }



    //serviceImpl
    public void delete(ShoppingCartDTO shoppingCartDTO) {
        //先根据id查找其数量 若大于1则更新
        ShoppingCart shoppingCart=new ShoppingCart();
        BeanUtils.copyProperties(shoppingCartDTO,shoppingCart);
        List<ShoppingCart> list = shoppingCartMapper.list(shoppingCart);
        ShoppingCart cart = list.get(0);
        if(cart.getNumber()==1){
            //若小于1则直接删除
            shoppingCartMapper.deleteById(cart.getId());
        }else if(cart.getNumber()>1){
            cart.setNumber(cart.getNumber()-1);
            cart.setCreateTime(LocalDateTime.now());
            shoppingCartMapper.updateNumberById(cart);
        }


    }


    //mapper
    @Update("update sky_take_out.shopping_cart set number = #{number} where id = #{id}")
    void updateNumberById(ShoppingCart cart);
    @Insert("insert into sky_take_out.shopping_cart (name, image, user_id, dish_id, setmeal_id, dish_flavor, amount, create_time) " +
            "VALUES (#{name},#{image},#{userId},#{dishId},#{setmealId},#{dishFlavor},#{amount},#{createTime})")
    void insert(ShoppingCart shoppingCart);
    @Delete("delete from sky_take_out.shopping_cart where id = #{id}")
    void deleteById(Long id);
    @Delete("delete from sky_take_out.shopping_cart where user_id = #{currentId}")
    void deleteByUseId(Long currentId);

如果有帮助到你,希望可以点赞收藏转发~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
苍穹外卖项目可以使用Postman进行API接口的测试和调试。Postman是一款常用的API开发工具,它可以帮助开发人员发送HTTP请求并查看响应结果,方便进行接口的测试和调试。 在苍穹外卖项目中,可以使用Postman发送各种类型的HTTP请求,比如GET、POST、PUT、DELETE等,来模拟用户操作和测试接口功能。通过Postman,可以验证接口的正确性、查看接口返回的数据、调试接口的参数等。 为了使用Postman进行苍穹外卖项目的接口测试,您需要以下步骤: 1. 下载并安装Postman:您可以从Postman官网(https://www.postman.com/)上下载并安装适合您的操作系统的版本。 2. 打开Postman并创建一个新的请求:打开Postman应用,在界面上选择"New"来创建一个新的请求。 3. 输入接口URL和选择请求方法:在新建请求的界面中,输入苍穹外卖项目的接口URL,并选择适当的请求方法,比如GET或POST。 4. 添加请求参数和请求头:根据需要,您可以添加请求参数和请求头,以便于模拟不同的请求情况。 5. 发送请求并查看响应:点击发送按钮,Postman会向服务器发送请求,并在界面上显示响应结果。您可以查看接口返回的数据、响应状态码等信息。 通过以上步骤,您可以使用Postman进行苍穹外卖项目的接口测试。这样可以帮助您确保接口的正确性和稳定性,提高项目的质量和用户体验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值