redis增大查询速度(项目中实际应用举例)

2024-06-24 08:18

本文主要是介绍redis增大查询速度(项目中实际应用举例),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、关于保存User表的方案

      1.1  使用Redis的Hash类型去保存关系型数据库的User表

       1.2 redis的Hash的key为"SYS_USER_TABLE_SEX_MAN",field:userid   value:json 数据


2、利用Redis的Set来保存满足一类条件的User用户的id信息。例如,性别为女,年龄大于25岁等条件。


3、Java实现的具体代码如下:

      3.1  Json相关的工具类   

public class GsonUtil {  public static String object2Json(Object object) {  Gson gson = new Gson();  return gson.toJson(object);  }  public static <T> T json2Object(String json, Class<T> clazz) {  Gson gson = new Gson();  return gson.fromJson(json, clazz);  }  
}  

      3.2  User实体类     

public class User {  private int id;  private String name;  private String sex;  private int age;  public User() {  }  public int getAge() {  return age;  }  public void setAge(int age) {  this.age = age;  }  public int getId() {  return id;  }  public void setId(int id) {  this.id = id;  }  public String getName() {  return name;  }  public void setName(String name) {  this.name = name;  }  public String getSex() {  return sex;  }  public void setSex(String sex) {  this.sex = sex;  }  @Override  public String toString() {  return "User [id=" + id + ", name=" + name + ", sex=" + sex + ", age="  + age + "]";  }  }  

      3.3   Redis实现类似SQL的多条件查询测试

public class RedisSQL {  public static void main(String[] args) {  // 将User表的内容放到Redis里面,下面为key  // 将User表的内容field:id value: json 保存一个记录  final String SYS_USER_TABLE = "SYS_USER_TABLE";  // 用于保存性别为男性的User用户的Redis的Set  final String SYS_USER_TABLE_SEX_MAN = "SYS_USER_TABLE_SEX_MAN";  // 用于保存性别为女性的用户的Redis的Set  final String SYS_USER_TABLE_SEX_FEMAN = "SYS_USER_TABLE_SEX_FEMAN";  // 用于保存age为25岁的用户的Redis的Set  final String SYS_USER_TABLE_AGE_25 = "SYS_USER_TABLE_AGE_25";  // 获取数据库的连接  Jedis jedis = new Jedis("192.168.2.116", 6379);  // 模拟数据库的表User的数据  List<User> users = new ArrayList<User>();  for (int i = 0; i < 5; i++) {  User user = new User();  user.setId(i);  user.setName("zhang" + i);  user.setSex("man");  user.setAge(20 + i);  users.add(user);  }  for (int i = 5; i < 10; i++) {  User user = new User();  user.setId(i);  user.setName("zhang" + i);  user.setSex("feman");  user.setAge(20 + i);  users.add(user);  }  // 通过Hash存放  Map<String, String> map = new HashMap<String, String>();  for (int i = 0; i < users.size(); i++) {  map.put(users.get(i).getId() + "",  GsonUtil.object2Json(users.get(i)));  // 将性别为男性的User用户  // 加入到Redis中key为SYS_USER_TABLE_SEX_MAN的Set集合里面  // 只需要加入User用户的id就可以了  if ("man".equals(users.get(i).getSex())) {  jedis.sadd(SYS_USER_TABLE_SEX_MAN, users.get(i).getId() + "");  }  // 将性别为男性的User用户  // 加入到Redis中key为SYS_USER_TABLE_SEX_MAN的Set集合里面  // 只需要加入User用户的id就可以了  if ("feman".equals(users.get(i).getSex())) {  jedis.sadd(SYS_USER_TABLE_SEX_FEMAN, users.get(i).getId() + "");  }  // 如果有age,birthday等,使用类似的方法  // 在Redis里面,新建立一个Set,用来保存符合条件的相关User的id信息  if ("25".equals(users.get(i).getAge() + "")) {  jedis.sadd(SYS_USER_TABLE_AGE_25, users.get(i).getId() + "");  }  }  // 查看转换结果  // Set<String> keySet = map.keySet();  // for (String key : keySet) {  // System.out.println(map.get(key));  // }  // 保存User表的数据到Redis中  // key为SYS_USER_TABLE  // 每条记录一 feild :id value:json 的形式保存  jedis.hmset(SYS_USER_TABLE, map);  // ===============================  // 模拟SQL的where多条件查询  // 查询年龄为25岁,性别为女的user用户  Set<String> sinter = jedis.sinter(SYS_USER_TABLE_SEX_FEMAN);  for (String key : sinter) {  // 根据id到Redis中的SYS_USER_TABLE,查询符合条件的user  String hkey = jedis.hget(SYS_USER_TABLE, key);  System.out.println(hkey);  // 将查询到的json数据,转换为User用户  User user = GsonUtil.json2Object(hkey, User.class);  System.out.println(user);  }  // 查询年龄为25岁,性别为女的user用户  Set<String> sinter2 = jedis.sinter(SYS_USER_TABLE_SEX_FEMAN,  SYS_USER_TABLE_AGE_25);  for (String key : sinter2) {  // 根据id到Redis中的SYS_USER_TABLE,查询符合条件的user  String hkey = jedis.hget(SYS_USER_TABLE, key);  System.out.println(hkey);  // 将查询到的json数据,转换为User用户  User user = GsonUtil.json2Object(hkey, User.class);  System.out.println(user);  }  }  
}  

这篇关于redis增大查询速度(项目中实际应用举例)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1089606

相关文章

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

Redis缓存问题与缓存更新机制详解

《Redis缓存问题与缓存更新机制详解》本文主要介绍了缓存问题及其解决方案,包括缓存穿透、缓存击穿、缓存雪崩等问题的成因以及相应的预防和解决方法,同时,还详细探讨了缓存更新机制,包括不同情况下的缓存更... 目录一、缓存问题1.1 缓存穿透1.1.1 问题来源1.1.2 解决方案1.2 缓存击穿1.2.1

redis-cli命令行工具的使用小结

《redis-cli命令行工具的使用小结》redis-cli是Redis的命令行客户端,支持多种参数用于连接、操作和管理Redis数据库,本文给大家介绍redis-cli命令行工具的使用小结,感兴趣的... 目录基本连接参数基本连接方式连接远程服务器带密码连接操作与格式参数-r参数重复执行命令-i参数指定命

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维