黑马点评商户查询缓存--缓存更新策略

ShopTypeServiceImpl类 代码

java 复制代码
package com.hmdp.service.impl;

import cn.hutool.json.JSONUtil;
import com.hmdp.dto.Result;
import com.hmdp.entity.ShopType;
import com.hmdp.mapper.ShopTypeMapper;
import com.hmdp.service.IShopTypeService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.hmdp.utils.RedisConstants;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;

import java.util.List;

/**
 * <p>
 * 服务实现类
 * </p>
 *
 * @author 虎哥
 * @since 2021-12-22
 */
@Service
public class ShopTypeServiceImpl extends ServiceImpl<ShopTypeMapper, ShopType> implements IShopTypeService {
    @Autowired
    private StringRedisTemplate redisTemplate;

    @Override
    public Result queryTypeList() {
        String key = RedisConstants.CACHE_SHOP_KEY;
        //从redis中获取列表数据
        String shopType = redisTemplate.opsForValue().get(key);
        //查询到数据,直接返回
        if (shopType != null) {
            List<ShopType> shopTypeList = JSONUtil.toList(shopType, ShopType.class);
            return Result.ok(shopTypeList);
        }
        //未查询到,查数据库
        List<ShopType> shopTypeList = query().orderByAsc("sort").list();
        String jsonStr = JSONUtil.toJsonStr(shopTypeList);
        //写入redis
        redisTemplate.opsForValue().set(key,jsonStr);
        //返回数据
        return Result.ok(shopTypeList);
    }
}
相关推荐
k***19514 小时前
Tomcat的升级
java·tomcat
j***495615 小时前
Windows操作系统部署Tomcat详细讲解
java·windows·tomcat
草莓熊Lotso15 小时前
unordered_map/unordered_set 使用指南:差异、性能与场景选择
java·开发语言·c++·人工智能·经验分享·python·网络协议
20岁30年经验的码农17 小时前
Spring Cloud Gateway 网关技术文档
java
likuolei18 小时前
XML DOM 节点类型
xml·java·服务器
w***744020 小时前
SpringBoot项目如何导入外部jar包:详细指南
spring boot·后端·jar
ZHE|张恒20 小时前
Spring Bean 生命周期
java·spring
百***490021 小时前
SQL Server查看数据库中每张表的数据量和总数据量
数据库·sql·oracle
代码or搬砖21 小时前
MyBatisPlus中的常用注解
数据库·oracle·mybatis
盼哥PyAI实验室21 小时前
MySQL 数据库入门第一课:安装、账户、库、表与数据操作详解
数据库·mysql