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

相关文章

Spring Integration Redis 使用示例详解

《SpringIntegrationRedis使用示例详解》本文给大家介绍SpringIntegrationRedis的配置与使用,涵盖依赖添加、Redis连接设置、分布式锁实现、消息通道配置及... 目录一、依赖配置1.1 Maven 依赖1.2 Gradle 依赖二、Redis 连接配置2.1 配置 R

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

Spring Boot项目如何使用外部application.yml配置文件启动JAR包

《SpringBoot项目如何使用外部application.yml配置文件启动JAR包》文章介绍了SpringBoot项目通过指定外部application.yml配置文件启动JAR包的方法,包括... 目录Spring Boot项目中使用外部application.yml配置文件启动JAR包一、基本原理

MyBatis流式查询两种实现方式

《MyBatis流式查询两种实现方式》本文详解MyBatis流式查询,通过ResultHandler和Cursor实现边读边处理,避免内存溢出,ResultHandler逐条回调,Cursor支持迭代... 目录MyBATis 流式查询详解:ResultHandler 与 Cursor1. 什么是流式查询?

Java慢查询排查与性能调优完整实战指南

《Java慢查询排查与性能调优完整实战指南》Java调优是一个广泛的话题,它涵盖了代码优化、内存管理、并发处理等多个方面,:本文主要介绍Java慢查询排查与性能调优的相关资料,文中通过代码介绍的非... 目录1. 事故全景:从告警到定位1.1 事故时间线1.2 关键指标异常1.3 排查工具链2. 深度剖析:

Springboot项目登录校验功能实现

《Springboot项目登录校验功能实现》本文介绍了Web登录校验的重要性,对比了Cookie、Session和JWT三种会话技术,分析其优缺点,并讲解了过滤器与拦截器的统一拦截方案,推荐使用JWT... 目录引言一、登录校验的基本概念二、HTTP协议的无状态性三、会话跟android踪技术1. Cook

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

DNS查询的利器! linux的dig命令基本用法详解

《DNS查询的利器!linux的dig命令基本用法详解》dig命令可以查询各种类型DNS记录信息,下面我们将通过实际示例和dig命令常用参数来详细说明如何使用dig实用程序... dig(Domain Information Groper)是一款功能强大的 linux 命令行实用程序,通过查询名称服务器并输

MySQL连表查询之笛卡尔积查询的详细过程讲解

《MySQL连表查询之笛卡尔积查询的详细过程讲解》在使用MySQL或任何关系型数据库进行多表查询时,如果连接条件设置不当,就可能发生所谓的笛卡尔积现象,:本文主要介绍MySQL连表查询之笛卡尔积查... 目录一、笛卡尔积的数学本质二、mysql中的实现机制1. 显式语法2. 隐式语法3. 执行原理(以Nes

SpringBoot利用树形结构优化查询速度

《SpringBoot利用树形结构优化查询速度》这篇文章主要为大家详细介绍了SpringBoot利用树形结构优化查询速度,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一个真实的性能灾难传统方案为什么这么慢N+1查询灾难性能测试数据对比核心解决方案:一次查询 + O(n)算法解决