目录
缓存菜品功能
清除缓存功能
缓存套餐功能
Spring Cache
添加购物车功能
查看购物车功能
清空购物车功能
删除单个菜品功能(作业)
如果大量用户访问,每次访问菜单都需要查询数据,服务器压力较大,因此使用Redis缓存。
实现思路:查询菜品是先判断是否有缓存,有则读取缓存,无则查询数据库后保存缓存,以供下一次查询。
缓存逻辑:每个分类下的菜品保存一份缓存数据。数据库中菜品数据变更时清理缓存数据。
@GetMapping("/list")
@ApiOperation("根据分类id查询菜品")
public Result> list(Long categoryId) {
//构造reedis中的key
String key="dish_"+categoryId;
ValueOperations valueOperations = redisTemplate.opsForValue();
//查询redis中是否存在菜品数据 放进去是什么类型,取回来就是什么类型
List list = (List) 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是一个框架,实现了基于注解的缓存功能,只需要简单地加一个注解,就能实现缓存功能。底层可以使用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 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);
如果有帮助到你,希望可以点赞收藏转发~