当前位置: 首页 > article >正文

【Redis】redis 存储的列表如何分页和检索

博主介绍:✌全网粉丝22W+,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌

技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物联网、机器学习等设计与开发。

感兴趣的可以先关注收藏起来,在工作中、生活上等遇到相关问题都可以给我留言咨询,希望帮助更多的人。

redis 存储的列表如何分页和检索

  • 一、Redis 列表的基本操作
  • 二、分页实现
  • 三、检索实现
    • 3.1 方法 1:客户端过滤
    • 3.2 方法 2:使用 Redis 的 SCAN 命令(适用于大数据量)
  • 四、分页 + 检索结合
  • 五、性能优化建议
  • 六、总结

在 Redis 中,列表(List)是一种有序的数据结构,通常用于存储一系列元素。由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能。

以下是 Redis 列表的分页和检索的实现方法:

一、Redis 列表的基本操作

在实现分页和检索之前,先回顾一下 Redis 列表的常用命令:

  • LPUSH key value: 在列表左侧插入一个元素。

  • RPUSH key value: 在列表右侧插入一个元素。

  • LRANGE key start stop: 获取列表中指定范围的元素(闭区间)。

  • LLEN key: 获取列表的长度。

  • LINDEX key index: 获取列表中指定索引的元素。

二、分页实现

Redis 的 LRANGE 命令可以用于分页。假设每页显示 pageSize 条数据,当前页为 page,则分页的逻辑如下:

  • 起始索引: start = (page - 1) * pageSize

  • 结束索引: end = start + pageSize - 1

示例代码

import redis.clients.jedis.Jedis;
import java.util.List;public class RedisListPagination {public static void main(String[] args) {// 连接 RedisJedis jedis = new Jedis("localhost", 6379);// 列表的 keyString key = "myList";// 每页显示的数量int pageSize = 5;// 当前页码(从 1 开始)int page = 2;// 计算分页的起始和结束索引int start = (page - 1) * pageSize;int end = start + pageSize - 1;// 使用 LRANGE 获取分页数据List<String> pageData = jedis.lrange(key, start, end);// 输出分页结果System.out.println("第 " + page + " 页数据: " + pageData);// 关闭连接jedis.close();}
}

三、检索实现

Redis 列表本身不支持直接的条件检索(如 SQL 中的 WHERE 语句),但可以通过以下方式实现检索:

3.1 方法 1:客户端过滤

使用 LRANGE 获取整个列表或分页数据,然后在客户端代码中进行过滤。

示例代码

import redis.clients.jedis.Jedis;
import java.util.List;
import java.util.stream.Collectors;public class RedisListSearch {public static void main(String[] args) {// 连接 RedisJedis jedis = new Jedis("localhost", 6379);// 列表的 keyString key = "myList";// 获取整个列表List<String> allData = jedis.lrange(key, 0, -1);// 在客户端进行过滤(例如:查找包含 "foo" 的元素)List<String> result = allData.stream().filter(item -> item.contains("foo")).collect(Collectors.toList());// 输出检索结果System.out.println("检索结果: " + result);// 关闭连接jedis.close();}
}

3.2 方法 2:使用 Redis 的 SCAN 命令(适用于大数据量)

如果列表数据量非常大,可以使用 SCAN 命令逐步遍历列表并进行过滤。

四、分页 + 检索结合

如果需要同时支持分页和检索,可以先在客户端进行过滤,然后对过滤后的结果进行分页。

示例代码:

import redis.clients.jedis.Jedis;
import java.util.List;
import java.util.stream.Collectors;public class RedisListPaginationAndSearch {public static void main(String[] args) {// 连接 RedisJedis jedis = new Jedis("localhost", 6379);// 列表的 keyString key = "myList";// 获取整个列表List<String> allData = jedis.lrange(key, 0, -1);// 在客户端进行过滤(例如:查找包含 "foo" 的元素)List<String> filteredData = allData.stream().filter(item -> item.contains("foo")).collect(Collectors.toList());// 分页参数int pageSize = 5;int page = 2;// 计算分页的起始和结束索引int start = (page - 1) * pageSize;int end = Math.min(start + pageSize, filteredData.size());// 获取分页数据List<String> pageData = filteredData.subList(start, end);// 输出分页结果System.out.println("第 " + page + " 页数据: " + pageData);// 关闭连接jedis.close();}
}

五、性能优化建议

  • 数据量较大时:

避免一次性获取整个列表(如 LRANGE key 0 -1),可以使用分步遍历(如 SCAN 命令)。

如果检索条件复杂,可以考虑使用 Redis 的其他数据结构(如 Sorted Set)或结合外部存储(如 Elasticsearch)。

  • 频繁检索时:

可以将列表数据同步到其他支持高效检索的存储中(如数据库或搜索引擎)。

  • 分页时:

如果列表数据量较大,尽量避免频繁分页操作,可以通过缓存分页结果来提高性能。

六、总结

  • 分页: 使用 LRANGE 命令实现分页。

  • 检索: 在客户端进行过滤,或使用 SCAN 命令逐步遍历。

  • 结合分页和检索: 先过滤,再对过滤后的结果进行分页。

  • 性能优化: 对于大数据量或复杂检索场景,考虑使用其他数据结构或外部存储。

通过以上方法,可以高效地实现 Redis 列表的分页和检索功能。


好了,今天分享到这里。希望你喜欢这次的探索之旅!不要忘记 “点赞” 和 “关注” 哦,我们下次见!🎈

本文完结!

祝各位大佬和小伙伴身体健康,万事如意,发财暴富,扫下方二维码与我一起交流!!!在这里插入图片描述

相关文章:

【Redis】redis 存储的列表如何分页和检索

博主介绍&#xff1a;✌全网粉丝22W&#xff0c;CSDN博客专家、Java领域优质创作者&#xff0c;掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围&#xff1a;SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...

2025.2.6 数模AI智能体大更新,更专业的比赛辅导,同提示词效果优于gpt-o1/o3mini、deepseek-r1满血

本次更新重新梳理了回复逻辑规则&#xff0c;无任何工作流&#xff0c;一共3.2k字细节描述。具体效果可以看视频&#xff0c;同时也比对了gpt-o1、gpt-o3mini、deepseek-r1-67BI&#xff0c;从数学建模题目解答上来看&#xff0c;目前我的数模AI智能体具有明显优势。 AI智能体优…...

如何在 Linux 中管理自定义脚本:将 ~/bin 目录添加到 $PATH

1. 前言 在 Linux Shell 中&#xff0c;$PATH 是一个非常重要的环境变量&#xff0c;它决定了系统在哪里寻找可执行命令。通过为 $PATH 添加自定义目录&#xff0c;你就能在任意位置方便地调用自己写的脚本或程序。本文将围绕这一主题&#xff0c;结合示例脚本 mycmd 以及 .ba…...

[LUA ERROR] bad light userdata pointer

Cocos2d项目&#xff0c;targetSdkVersion30&#xff0c;在 android 13 设备运行报错: [LUA ERROR] bad light userdata pointer &#xff0c;导致黑屏。 参考 https://blog.csdn.net/sdsabc2000/article/details/135384162的方法 下载最新的Cocos2dx 4.0,将其中的luajit &am…...

cursor指令工具

Cursor 工具使用指南与实例 工具概览 Cursor 提供了一系列强大的工具来帮助开发者提高工作效率。本指南将通过具体实例来展示这些工具的使用方法。 1. 目录文件操作 1.1 查看目录内容 (list_dir) 使用 list_dir 命令可以查看指定目录下的文件结构: 示例: list_dir log…...

【玩转全栈】----Django模板语法、请求与响应

目录 一、引言 二、模板语法 三、传参 1、视图函数到模板文件 2、模板文件到视图函数 四、引入静态文件 五、请求与响应 ?1、请求 2、响应 六、综合小案例 1、源码展示 2、注意事项以及部分解释 3、展示 一、引言 像之前那个页面&#xff0c;太过简陋&#xff0c;而且一个完整…...

2025年2月9日(数据分析,在最高点和最低点添加注释,添加水印)

要在最高点和最低点添加文本注释,可以使用 plt.annotate() 函数。这个函数允许你在图表中的特定位置添加文本注释,并且可以指定箭头指向特定的数据点。 以下是修改后的代码,添加了在最高点和最低点的文本注释: from matplotlib import pyplot as plt from matplotlib imp…...

C++,设计模式,【单例模式】

文章目录 一、模式定义与核心价值二、模式结构解析三、关键实现技术演进1. 基础版(非线程安全)2. 线程安全版(双重检查锁)3. 现代C++实现(C++11起)四、实战案例:全局日志管理器五、模式优缺点深度分析✅ 核心优势⚠️ 潜在缺陷六、典型应用场景七、高级实现技巧1. 模板化…...

今日AI和商界事件(2025-02-08)

今日AI领域的重大事件主要包括以下几个方面&#xff1a; 一、DeepSeek引发的行业震动 事件概述&#xff1a;DeepSeek作为近期崛起的AI模型&#xff0c;以其低成本、高性能的推理能力引发了广泛关注。其开源策略、独特的出身以及强大的算力表现&#xff0c;使得微软、英伟达等…...

C# LINQ与集合类 数据操作

目录 LINQ语法 过滤数据 投影数据 排序数据 集合操作 聚合操作 分组操作 查找元素 其他操作 常用的集合类 List LinkedList HashSet Dictionary List&#xff1a;动态数组 LinkedList&#xff1a;双向链表 HashSet&#xff1a;唯一无序集合 Dictionary&…...

开源流程引擎对比:compileflow、Turbo、Warm-Flow、 flowable、activiti

文章目录 开源流程引擎对比I 工作流引擎阿里的Compileflowflowableactivitiwarm-flow(国产)Turbo (didiopensource)II 知识扩展开发流程开源流程引擎对比 ActivitiCamundaCompileflowturbo核心表量282205特性 中断可重入√√√支持回滚√√运行模式独立运行和内嵌独立运行和…...

golang使用sqlite3,开启wal模式,并发读写

因为sqlite是基于文件的&#xff0c;所以默认情况下&#xff0c;sqlite是不支持并发读写的&#xff0c;即写操作会阻塞其他操作&#xff0c;同时sqlite也很容易就产生死锁。 但是作为一个使用广泛的离线数据库&#xff0c;从sqlite3.7.0版本开始&#xff08;SQLite Release 3.…...

基于yolov11的阿尔兹海默症严重程度检测系统python源码+onnx模型+评估指标曲线+精美GUI界面

【算法介绍】 基于YOLOv11的阿尔兹海默症严重程度检测系统是一种创新的医疗辅助工具&#xff0c;旨在通过先进的计算机视觉技术提高阿尔兹海默症的早期诊断和病情监测效率。阿尔兹海默症是一种渐进性的神经退行性疾病&#xff0c;通常表现为认知障碍、记忆丧失和语言障碍等症状…...

UV - Python 包管理

文章目录 创建 uv 项目已有项目已有uv项目 创建 uv 项目 # 创建项目 uv init m3 # 创建环境 cd m3 uv venv --python 3.11 # 激活环境 source .venv/bin/activate # 添加库 uv add flask 如果创建项目后&#xff0c;给库取别的名字&#xff0c;add 的时候&#xff0c;会…...

设计模式-生产者消费者模型

阻塞队列&#xff1a; 在介绍生产消费者模型之前&#xff0c;我们先认识一下阻塞队列。 阻塞队列是一种支持阻塞操作的队列&#xff0c;常用于生产者消费者模型&#xff0c;它提供了线程安全的队列操作&#xff0c;并且在队列为空或满时&#xff0c;能够阻塞等待&#xff0c;…...

RabbitMQ介绍以及基本使用

文章目录 一、什么是消息队列&#xff1f; 二、消息队列的作用&#xff08;优点&#xff09; 1、解耦 2、流量削峰 3、异步 4、顺序性 三、RabbitMQ基本结构 四、RabbitMQ队列模式 1、简单队列模式 2、工作队列模式 3、发布/订阅模式 4、路由模式 5、主题模式 6、…...

shell解决xml文本中筛选的问题

shell解决xml文本中筛选的问题&#xff0c;将xml文件中多余的配置删除掉&#xff0c;达到符合单一配置的结果。 过于简单就不废话了。 #!/bin/bashconf_file$1 flag0 temp_file"__temp.xml"if [ -f "${temp_file}" ];thenrm "${temp_file}" fi …...

嵌入式硬件篇---OpenMV的硬件流和软件流

文章目录 前言一、硬件流控制&#xff08;Hardware Flow Control&#xff09;1. 基本原理RTSCTS 2. OpenMV中的实现• 硬件要求• 代码配置• 工作流程 二、软件流控制&#xff08;Software Flow Control&#xff09;1. 基本原理XONXOFF 2. OpenMV中的实现• 代码配置• 工作流…...

1.6 学习测试用例(Test)分为几步?

文章目录 前言一、什么是UVM中的测试用例&#xff08;Test&#xff09;&#xff1f;二、如何理解UVM中的测试用例&#xff1f;三、如何使用UVM中的测试用例&#xff1f;四、实操代码示例4.1代码结构4.2 代码实现4.2.1 a. 测试用例类的定义和实现4.2.2 b. 测试环境的构建和配置4…...

PDF2.0 投影注释(Projection annotations)

投影注释是PDF2.0新标准中新增加的注释类型&#xff0c;属于标记注释的子类型&#xff0c;因此&#xff0c;它具有很多其他标记注释的功能。 然而&#xff0c;投影注释仅在特定的运行时环境的上下文中有效&#xff0c;例如已激活的3D模型。 投影注释的注释字典包含了所有注释字…...

【AIGC提示词系统】基于 DeepSeek R1 + ClaudeAI 易经占卜系统

上篇因为是VIP&#xff0c;这篇来一个免费的 提示词在最下方&#xff0c;喜欢的点个关注吧 引言 在人工智能与传统文化交融的今天&#xff0c;如何让AI系统能够传递传统易经文化的智慧&#xff0c;同时保持易经本身的神秘感和权威性&#xff0c;是一个极具挑战性的课题。本文将…...

OpenAI 实战进阶教程 - 第十节 : 结合第三方工具的向量数据库Pinecone

面向读者群体 本节课程主要面向有一定编程基础和数据处理经验的计算机从业人员&#xff0c;如后端开发工程师、数据工程师以及对 AI 应用有浓厚兴趣的技术人员。即使你之前没使用过向量数据库&#xff0c;也可以通过本节的实操内容快速上手&#xff0c;为企业或个人项目构建强…...

深入Linux系列之进程地址空间

深入Linux系列之进程地址空间 1.引入 那么在之前的学习中&#xff0c;我们知道我们创建一个子进程的话&#xff0c;我们可以在代码层面调用fork函数来创建我们的子进程&#xff0c;那么fork函数的返回值根据我们当前所处进程的上下文是返回不同的值&#xff0c;它在父进程中返…...

AWK系统学习指南:从文本处理到数据分析的终极武器 介绍

目录 一、AWK核心设计哲学解析 1.1 记录与字段的原子模型 1.2 模式-动作范式 二、AWK编程语言深度解析 2.1 控制结构 说明&#xff1a; 2.2 关联数组 代码说明&#xff1a; 示例输入和输出&#xff1a; 注意事项&#xff1a; 2.3 内置函数库 三、高级应用技巧 3.1…...

250207-MacOS修改Ollama模型下载及运行的路径

在 macOS 上&#xff0c;Ollama 默认将模型存储在 ~/.ollama/models 目录。如果您希望更改模型的存储路径&#xff0c;可以通过设置环境变量 OLLAMA_MODELS 来实现。具体步骤如下&#xff1a; 选择新的模型存储目录&#xff1a;首先&#xff0c;确定您希望存储模型的目标目录路…...

1、http介绍

一、HTTP 和 HTTPS 简介 HTTP&#xff08;HyperText Transfer Protocol&#xff09; 用途&#xff1a;用于网页数据传输&#xff08;不加密&#xff09;。协议特性&#xff1a;以明文形式传输数据&#xff0c;默认端口 80&#xff0c;无身份验证和完整性保护。典型场景&#xf…...

半导体行业跨网文件交换系统

在当今这个数字化转型的时代&#xff0c;半导体行业作为技术密集型产业&#xff0c;正面临着前所未有的信息安全挑战。随着企业内外网隔离措施的加强&#xff0c;如何实现既安全又高效的跨网文件交换&#xff0c;成为了众多半导体企业的一大难题。 特别是在研发和生产过程中产生…...

使用GD32F470的硬件SPI读写W25Q64

代码简单改下引脚定义便可以使用&#xff01; 使用的单片机具体型号&#xff1a;GD32F470ZGT6 简单介绍下W25Q64&#xff1a; /* W25Q64 性能参数 */ /* 容量&#xff1a;8MByte 64Mbit */ /* 有128个块&#xff0c;每个块有64KByte */ /* 每个块有16个扇区&#xff0c;每个…...

02为什么 OD门和 OC门输出必须加上拉电阻?

为什么 OD&#xff08;开漏&#xff09;门和 OC&#xff08;开集&#xff09;门输出必须加上拉电阻&#xff1f; 1、首先一点&#xff0c;知道OD是说的MOS管&#xff0c;OC是说的三极管&#xff0c;二者的区别与联系大家应该都懂。 2、以OC门举例&#xff0c;芯片的OC门内部结…...

保姆级教程--DeepSeek部署

以DeepSeek-R1或其他类似模型为例&#xff0c;涵盖环境配置、代码部署和运行测试的全流程&#xff1a; 准备工作 1. 注册 Cloud Studio - 访问 [Cloud Studio 官网](https://cloudstudio.net/)&#xff0c;使用腾讯云账号登录。 - 完成实名认证&#xff08;如需长期使用…...