Redis应用之SortedSet的使用

Redis应用之SortedSet的使用前言 相对来说我们是比较深度使用 redis 的 在推荐瀑布流和排行榜等好多的场景我们主要是用的是 SortedSet 今天来说一说 SortedSet 一 基本的用法插入数据 常用的有 ZADD 和 ZINCRBY 使用方法 Longzadd byte key doublescore byte member 插入数据 比我们的推荐场景中 根据用户的行为数据 推荐出来的数据会存放到 red

前言:相对来说我们是比较深度使用redis的,在推荐瀑布流和排行榜等好多的场景我们主要是用的是SortedSet,今天来说一说SortedSet

redis集群监控

一、基本的用法

  1. 插入数据,常用的有ZADDZINCRBY
    • 使用方法Long zadd(byte[] key, double score, byte[] member)插入数据,比我们的推荐场景中,根据用户的行为数据,推荐出来的数据会存放到redis中,就是调用这个方法,插入要推荐的数据
    • 使用方法Double zincrby(byte[] key, double score, byte[] member)对已有的数据的score的值进行增减,比如我们的搜索词排行,用户输入一个搜索词之后,经历一定的清洗后会把对应的词存入redis中,score记入1,以后每多搜索一次,调用ZINCRBY对这个搜索词加1
  2. 删除数据,常用的有ZREM,ZREMRANGEBYSCORE
    • 使用方法Long zrem(byte[] key, byte[]... member)删除集合中给定的元素,可以是多个,不存在的成员将被忽略
    • 使用方法Long zremrangeByScore(byte[] key, double start, double end)删除集合中给定score区间的元素,其中start可以是’-inf’,end可以是‘+inf’
  3. 查询数据,常用的有ZRANGE,ZRANGEBYSCORE,ZREVRANGE,ZREVRANGEBYSCORE
    • 使用方法Set

      zrange(byte[] key, long start, long end)
      返回有序集 key 中,指定区间内的成员,其中成员的位置按 score 值递增(从小到大)来排序
    • 使用方法Set

      zrevrange(byte[] key, long start, long end)
      返回有序集 key 中,指定区间内的成员,其中成员的位置按 score 值递增(从大到小)来排序
    • 使用方法Set

      zrangeByScore(byte[] key, double min, double max)
      返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从小到大)次序排列
    • 使用方法Set

      zrevrangeByScore(byte[] key, double min, double max)
      返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员。有序集成员按 score 值递增(从大到小)次序排列
    • 使用方法Set

      zrangeByScoreWithScores(byte[] key, double min, double max)
      返回有序集 key 中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员及score。有序集成员按 score 值递增(从小到大)次序排列

二、注意点

  1. ZINCRBY可以对当前键值的score进行增减操作,减的操作传入负数的score值即可,如果插入的数据不存在,当前key不存在,score即为传入的score,如果key存在则当前的score加上redis本身存在的score为最终的结果
  2. 查询数据,慎用全量的操作,尤其是在不确定当前的键中的结果集合的大小的情况,如果一定要用最好先判断一下当前的键中结果集合的大小,根据大小分批次获取,一般建议一次查询返回的数据量在10KB一下,不过到几百KB也是可以接受的,如果再大的话,需要考虑一下性能

三、问题

  1. redis如何保证查询的数据的顺序性?
    通过查看源代码,我们可以知道,redis的返回的结果集使用的是LinkedHashSet,保存返回结果集合的
    private Set<Tuple> getTupledSet() { 
           checkIsInMultiOrPipeline(); List<String> membersWithScores = client.getMultiBulkReply(); if (membersWithScores == null) { 
           return Collections.emptySet(); } if (membersWithScores.isEmpty()) { 
           return Collections.emptySet(); } Set<Tuple> set = new LinkedHashSet<Tuple>(membersWithScores.size() / 2, 1.0f); Iterator<String> iterator = membersWithScores.iterator(); while (iterator.hasNext()) { 
           set.add(new Tuple(iterator.next(), Double.valueOf(iterator.next()))); } return set; } 


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/178638.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午4:49
下一篇 2026年3月26日 下午4:49


相关推荐

  • tika提取html,TIKA内容提取

    tika提取html,TIKA内容提取Tika 使用不同的解析器库来提取给解析器的内容 它选择了正确的语法分析器提取给定的文档类型 解析文件 一般用于 Tika 外观 facade 类的 parseToStrin 方法 下面显示的是所涉及分析过程的步骤和这些由 Tika 的 ParsertoStri 方法提取 抽象的分析过程 最初 当我们传一个文件到 Tika 它使用与之适合的类型检测机制和检测文件类型 一旦文档类型是已知的 它选择从解析器库中

    2026年3月17日
    2
  • mybatis的rowbounds是物理分页吗_rowbounds分页

    mybatis的rowbounds是物理分页吗_rowbounds分页mybatis中,使用RowBounds分页,非常方便不需要在sql语句中写limit,mybatis会自动拼接sql,添加limit最核心的是在mapper接口层,传参时传入RowBounds(intoffset,intlimit)对象,即可完成分页注意:由于java允许的最大整数为2147483647,所以limit能使用的最大整数也是…

    2026年2月19日
    4
  • java hashmap和treemap_java中treemap和hashmap的区别是什么?

    java hashmap和treemap_java中treemap和hashmap的区别是什么?区别 1 HashMap 中元素是没有顺序的 TreeMap 中所有元素都是有某一固定顺序的 2 HashMap 继承 AbstractMap 类 是基于 hash 表实现的 TreeMap 继承 SortedMap 类 是基于红黑树实现的 TreeMap 和 HashMap 的区别 Map 在数组中是通过数组下标来对其内容进行索引的 而 Map 是通过对象来对对象进行索引的 用来索引的对象叫键 key 其对应的对象叫值 va

    2025年8月24日
    5
  • Git简易的命令行入门教程

    Git简易的命令行入门教程

    2021年11月22日
    57
  • java IO流详尽解析「建议收藏」

    java IO流详尽解析「建议收藏」流的概念和作用,好吧,百度了一张图片,不错学习JavaIO,不得不提到的就是JavaIO流。流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象。即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,方便更直观的进行数据操作。IO流的分类根据处理数据类型的不同分为:字符流和字节流根据数据流向不同分为:输入流和输出流字符流和字节流字符流的由

    2022年5月22日
    40
  • 旧手机别扔!装个OpenClaw,立刻变成实用AI机器人

    旧手机别扔!装个OpenClaw,立刻变成实用AI机器人

    2026年3月12日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号