Redis缓存数据库表(列单独缓存)

​ 在Redis中缓存数据库表数据,而不使用JSON结构来表示value,通常意味着我们会将数据库表的每一行数据映射为Redis中的一个或多个键值对。下面是一个简单的Java示例,展示了如何使用Jedis库来缓存数据库表的部分数据。

​ 假设我们有一个User表,它包含idusernameemail字段,我们想要缓存idusername

​ 首先,添加Jedis依赖到你的pom.xml中:

xml 复制代码
<dependencies>  
    <!-- 其他依赖... -->  
    <dependency>  
        <groupId>redis.clients</groupId>  
        <artifactId>jedis</artifactId>  
        <version>3.7.0</version> 
    </dependency>  
</dependencies>

​ 然后,创建User类和相关的操作类:

java 复制代码
import redis.clients.jedis.Jedis;  
  
// 数据库中的User表对应的Java类  
class User {  
    private int id;  
    private String username;  
    private String email;  
  
    // 构造器、getter和setter方法...  
}  
  
// Redis操作类  
class RedisCache {  
    private Jedis jedis;  
  
    public RedisCache(String host, int port) {  
        jedis = new Jedis(host, port);  
    }  
  
    // 缓存User数据  
    public void cacheUser(User user) {  
        String userIdKey = "user:id:" + user.getId();  
        String usernameKey = "user:username:" + user.getId();  
          
        jedis.set(userIdKey, String.valueOf(user.getId()));  
        jedis.set(usernameKey, user.getUsername());  
    }  
  
    // 根据ID获取缓存中的User数据  
    public User getUserById(int id) {  
        String userIdKey = "user:id:" + id;  
        String usernameKey = "user:username:" + id;  
          
        String userId = jedis.get(userIdKey);  
        String username = jedis.get(usernameKey);  
          
        if (userId != null && username != null) {  
            User user = new User();  
            user.setId(Integer.parseInt(userId));  
            user.setUsername(username);  
            // 注意:这里我们没有缓存email,所以需要从数据库获取或设为null  
            // 根据实际需求,你也可以选择缓存email或其他字段  
            return user;  
        }  
        return null;  
    }  
  
    // 关闭连接  
    public void close() {  
        if (jedis != null) {  
            jedis.close();  
        }  
    }  
}  
  
// 主类,用于演示如何使用RedisCache  
public class RedisCacheExample {  
    public static void main(String[] args) {  
        RedisCache redisCache = new RedisCache("localhost", 6379);  
  
        // 假设这是从数据库获取的User对象  
        User userFromDatabase = new User();  
        userFromDatabase.setId(1);  
        userFromDatabase.setUsername("john_doe");  
        userFromDatabase.setEmail("john.doe@example.com");  
  
        // 将User对象缓存到Redis中  
        redisCache.cacheUser(userFromDatabase);  
  
        // 从Redis中根据ID获取User对象  
        User cachedUser = redisCache.getUserById(1);  
        if (cachedUser != null) {  
            System.out.println("Cached User ID: " + cachedUser.getId());  
            System.out.println("Cached Username: " + cachedUser.getUsername());  
        } else {  
            System.out.println("User not found in cache");  
        }  
  
        // 关闭Redis连接  
        redisCache.close();  
    }  
}

​ 在这个例子中,我们创建了一个RedisCache类来管理Redis中的操作。cacheUser方法用于将User对象的部分信息(这里是idusername)存储到Redis中,而getUserById方法则根据ID从Redis中检索这些信息并重新构建User对象。注意,我们没有缓存email字段,所以如果你需要它,你需要从数据库获取或根据业务需求处理。

​ 这个示例没有包含实际的数据库访问代码,因为这取决于你使用的具体数据库和ORM框架。在实际应用中,你会从数据库中获取User对象,然后调用cacheUser方法将其缓存到Redis中。当需要获取用户信息时,首先尝试从Redis中通过getUserById方法获取,如果Redis中没有,再回退到数据库查询。

相关推荐
九皇叔叔1 小时前
【9】PostgreSQL 之 vacuum 死元组清理
数据库·postgresql
风雅的远行者1 小时前
mysql互为主从失效,重新同步
数据库·mysql
晨岳1 小时前
CentOS 安装 JDK+ NGINX+ Tomcat + Redis + MySQL搭建项目环境
java·redis·mysql·nginx·centos·tomcat
执笔诉情殇〆1 小时前
前后端分离(java) 和 Nginx在服务器上的完整部署方案(redis、minio)
java·服务器·redis·nginx·minio
宇钶宇夕2 小时前
S7-1200 系列 PLC 中 SCL 语言的 PEEK 和 POKE 指令使用详解
运维·服务器·数据库·程序人生·自动化
绿蚁新亭2 小时前
Spring的事务控制——学习历程
数据库·学习·spring
都叫我大帅哥3 小时前
🌟 Redis缓存与数据库数据一致性:一场数据世界的“三角恋”保卫战
redis
都叫我大帅哥3 小时前
Redis缓存雪崩:一场本可避免的"雪崩"灾难
redis
不像程序员的程序媛3 小时前
redis的一些疑问
java·redis·mybatis
scilwb3 小时前
占用栅格地图数据集
数据库