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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、