项目记录:利用Redis实现缓存以提升查询效率

一、概述

当我们查询所有数据时,如果缓存中没有,则去数据库查询,如果有,直接查缓存的数据就行。注意定期更新缓存数据。

二、主体代码

java 复制代码
    private static final String ROOM_SCHEDULES_HASH = "RoomSchedules";

    @Override
    public List<RoomSchedule> getAllRoomSchedules()  {
        BoundHashOperations<String, String, String> hashOps = stringRedisTemplate.boundHashOps(ROOM_SCHEDULES_HASH);
        if (hashOps.size() == 0) {
            List<RoomSchedule> roomSchedules = roomScheduleMapper.getAllRoomSchedules();
            for (RoomSchedule roomSchedule : roomSchedules) {
                ObjectMapper objectMapper = new ObjectMapper();
                try {
                    String json = objectMapper.writeValueAsString(roomSchedule);
                    hashOps.put(roomSchedule.getId().toString(), json);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
            stringRedisTemplate.expire(ROOM_SCHEDULES_HASH, 3, TimeUnit.MINUTES);  // 设置有效期为三分钟
            return roomSchedules;
        } else {
            Map<String, String> entries = hashOps.entries();

            List<RoomSchedule> roomSchedules = new ArrayList<>();
            for (String json : entries.values()) {
                try {
                    ObjectMapper objectMapper = new ObjectMapper();
                    RoomSchedule roomSchedule = objectMapper.readValue(json, RoomSchedule.class);
                    roomSchedules.add(roomSchedule);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
            return roomSchedules;
        }

       
    }

BoundHashOperations是绑定键值的方法,意味着之后的操作都是对此键进行操作。

ObjectMapper类提供了一系列json序列化和反序列化的操作。

缓存更新操作是通过设置TTL有效期来实现的。

三、效果实现

可以看到引入Redis缓存后,查询效率明显提升。

相关推荐
陌上丨4 小时前
Redis的Key和Value的设计原则有哪些?
数据库·redis·缓存
AI_56784 小时前
AWS EC2新手入门:6步带你从零启动实例
大数据·数据库·人工智能·机器学习·aws
ccecw4 小时前
Mysql ONLY_FULL_GROUP_BY模式详解、group by非查询字段报错
数据库·mysql
JH30735 小时前
达梦数据库与MySQL的核心差异解析:从特性到实践
数据库·mysql
数据知道5 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
麦聪聊数据6 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
未来之窗软件服务6 小时前
数据库优化提速(四)新加坡房产系统开发数据库表结构—仙盟创梦IDE
数据库·数据库优化·计算机软考
时艰.7 小时前
Java 并发编程 — 并发容器 + CPU 缓存 + Disruptor
java·开发语言·缓存
Goat恶霸詹姆斯7 小时前
mysql常用语句
数据库·mysql·oracle
大模型玩家七七8 小时前
梯度累积真的省显存吗?它换走的是什么成本
java·javascript·数据库·人工智能·深度学习