news 2026/1/15 6:02:32

redis分页查询

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
redis分页查询

redis不仅可以存普通文本,还可以存入List,这里就整理了下用redis做分页查询的功能。首先定义一个redis工具类,这里只贴出了需要的方法。

public class RedisUtils { private JedisPool pool; public RedisUtils() { if (pool == null) { JedisPoolConfig config = new JedisPoolConfig(); config.setMaxIdle(10); config.setTestOnBorrow(true); pool = new JedisPool(config, 127.0.0.1, 6379, 100000); } } /** * <p> * 通过key向list尾部添加字符串 * </p> * * @param key * @param strs * 可以使一个string 也可以使string数组 * @return 返回list的value个数 */ public Long rpush(String key, String... strs) { Jedis jedis = null; Long res = null; try { jedis = pool.getResource(); res = jedis.rpush(key, strs); } catch (Exception e) { pool.returnBrokenResource(jedis); e.printStackTrace(); } finally { returnResource(pool, jedis); } return res; } /** * 获取key当前页的list * @param key * @param curr * @param pageSize * @return */ public List<String> page(String key, int curr, int pageSize){ Jedis jedis = null; String res = null; List<String> lrange = null; try { jedis = pool.getResource(); lrange = jedis.lrange(key, (curr - 1) * pageSize, curr * pageSize); } catch (Exception e) { pool.returnBrokenResource(jedis); e.printStackTrace(); } finally { returnResource(pool, jedis); } return lrange; } /** * 获取key的总条数 * @param key * @return */ public long count(String key){ Jedis jedis = null; long total = 0L; try { jedis = pool.getResource(); total = jedis.llen(key); } catch (Exception e) { pool.returnBrokenResource(jedis); e.printStackTrace(); } finally { returnResource(pool, jedis); } return total; } }

接下来是应用层的调用

//这里演示存入redis的操作 public static void main(String[] args) { RedisUtils redisUtils = new RedisUtils(); for(int i=0;i<1000;i++){ HashMap<String, Object> map = new HashMap<>(); map.put("key_"+i, "value_"+i); //存入redis redisUtils.rpush("key", map.toString()); } } //这里演示读取redis数据的操作 public static void main(String[] args) { RedisUtils redisUtils = new RedisUtils(); //获取当前页的数据,1代表当前页 10代表每页条数 List<String> list = redisUtils.page("key", 1, 10); //获取总条数 long count = redisUtils.count("key"); }

redis分页查询效率很高,对于不需要持久化的数据可以使用此方案。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/14 23:36:05

NX微控制器抽象层开发核心要点解析

一次编码&#xff0c;处处运行&#xff1a;深入理解NX微控制器抽象层的设计精髓 你有没有遇到过这样的场景&#xff1f;项目刚做完原型验证&#xff0c;老板一句话“换颗国产MCU降成本”&#xff0c;整个团队就得推倒重来——SPI时钟极性不对、GPIO初始化顺序出错、UART中断丢…

作者头像 李华
网站建设 2026/1/14 4:04:56

Redis--模糊查询--方法实例

原文网址&#xff1a;Redis–模糊查询–方法/实例_IT利刃出鞘的博客-CSDN博客 简介 说明 本文介绍Redis模糊查询的方法。 官网网址 https://redis.io/commands/keys/ https://redis.io/commands/scan/ Redis模糊查询键的方法 Redis提供了两种模糊查询键的方法&#xff…

作者头像 李华
网站建设 2026/1/14 13:23:47

定位内存访问违例:HardFault_Handler项目应用实例

定位内存访问违例&#xff1a;一次硬故障引发的深度调试之旅你有没有遇到过这样的场景&#xff1f;设备在现场运行得好好的&#xff0c;突然毫无征兆地重启。你接上调试器反复测试&#xff0c;却怎么也复现不了问题。日志里没有线索&#xff0c;断点无处下手——仿佛系统被“幽…

作者头像 李华
网站建设 2026/1/14 20:00:32

HY-MT1.5部署监控方案:GPU利用率与QPS实时观测实战

HY-MT1.5部署监控方案&#xff1a;GPU利用率与QPS实时观测实战 1. 引言 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的翻译模型成为智能应用的核心组件之一。腾讯开源的混元翻译大模型 HY-MT1.5 系列&#xff0c;凭借其卓越的翻译性能和灵活的部署能力&#xff…

作者头像 李华
网站建设 2026/1/14 5:31:11

STM32F1/F4系列Keil5芯片包下载完整示例

STM32F1/F4系列Keil5芯片包下载实战指南&#xff1a;从环境搭建到高效开发的底层逻辑你有没有遇到过这样的场景&#xff1f;刚装好Keil Vision&#xff0c;信心满满地新建工程&#xff0c;结果在选择芯片型号时——下拉框里居然找不到你的STM32F407VG&#xff1f;或者编译时报出…

作者头像 李华
网站建设 2026/1/13 22:58:20

HY-MT1.5-7B微调教程:领域自适应训练部署全流程

HY-MT1.5-7B微调教程&#xff1a;领域自适应训练部署全流程 1. 引言 随着全球化进程的加速&#xff0c;高质量、低延迟的机器翻译需求日益增长。腾讯开源的混元翻译大模型 HY-MT1.5 系列应运而生&#xff0c;旨在为多语言互译场景提供高性能、可定制化的解决方案。该系列包含…

作者头像 李华