19.缓存的认识和基本使用

缓存介绍

缓存是数据交换的缓冲区Cache,是临时存储数据的地方,一般读写性能较高。

数据库的缓存就是建立索引。

缓存的作用

1.降低后端负载。

2.提高读写效率,降低响应时间。

缓存的问题

1.保证数据的一致性。

2.增加代码维护成本。解决一些常见的缓存问题。

3.增加运维成本,会搭建一些缓存的集群部署。

String类型

java 复制代码
 @Autowired
    private StringRedisTemplate stringRedisTemplate;

 @Override
    public Result queryById(Long id) {
        String key = RedisConstants.CACHE_SHOP_KEY + id;
        //从redis中查询商铺缓存
        String shopJsonStr = stringRedisTemplate.opsForValue().get(key);
        //redis中有数据直接返回
        if(StrUtil.isNotBlank(shopJsonStr)) {
            Shop shop = JSONUtil.toBean(shopJsonStr, Shop.class);
            return Result.ok(shop);
        }
        //redis中没有数据,继续查询数据库
        Shop shop = getById(id);
        if(ObjectUtil.isNull(shop)) {
            //数据库没有查询到数据,返回错误
            return Result.fail("店铺不存在");
        }
        //数据库中查询到数据,存入redis,再返回数据
        stringRedisTemplate.opsForValue().set(key, JSONUtil.toJsonStr(shop));
        return Result.ok(shop);
    }

List类型

java 复制代码
@Autowired
    private StringRedisTemplate stringRedisTemplate;

    @Override
    public Result queryTypeList() {

        String key = "cache:shopType:all";

        List<String> shopTypeList = stringRedisTemplate.opsForList().range(key, 0, -1);
        if(CollectionUtil.isNotEmpty(shopTypeList)) {
            List<ShopType> shopTypes = new ArrayList<>();
            shopTypeList.stream().forEach(e -> {
                ShopType shopType = JSONUtil.toBean(e, ShopType.class);
                shopTypes.add(shopType);
            });
            return Result.ok(shopTypes);
        }

        List<ShopType> shopTypes = query().orderByAsc("sort").list();
        if(CollectionUtil.isEmpty(shopTypes)) {
            return Result.ok("没有找到店铺类型");
        }

        shopTypes.stream().forEach(e -> shopTypeList.add(JSONUtil.toJsonStr(e)));
        stringRedisTemplate.opsForList().rightPushAll(key, shopTypeList);
        return Result.ok(shopTypes);
    }
相关推荐
黄名富4 小时前
Redis 附加功能(二)— 自动过期、流水线与事务及Lua脚本
java·数据库·redis·lua
G_whang4 小时前
centos7下docker 容器实现redis主从同步
redis·docker·容器
.生产的驴5 小时前
SpringBoot 对接第三方登录 手机号登录 手机号验证 微信小程序登录 结合Redis SaToken
java·spring boot·redis·后端·缓存·微信小程序·maven
我叫啥都行8 小时前
计算机基础复习12.22
java·jvm·redis·后端·mysql
阿乾之铭8 小时前
Redis四种模式在Spring Boot框架下的配置
redis
on the way 12310 小时前
Redisson锁简单使用
redis
科马11 小时前
【Redis】缓存
数据库·redis·spring·缓存
mxbb.13 小时前
单点Redis所面临的问题及解决方法
java·数据库·redis·缓存
weisian1511 天前
Redis篇--常见问题篇3--缓存击穿(数据查询上锁,异步操作,熔断降级,三种缓存问题综合优化策略)
数据库·redis·缓存
HEU_firejef1 天前
redis——布隆过滤器
数据库·redis·缓存