Redis 有序集合(sorted set)

举报
孙中明 发表于 2022/01/23 01:07:55 2022/01/23
【摘要】 Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。 不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。 有序集合的成员是唯一的,但分数(score)却可以重复。 集合是通过哈希表实现的,所以添加,删除...

Redis 有序集合(sorted set)

Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

有序集合的成员是唯一的,但分数(score)却可以重复。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

 

list链表类型: 内部存储的元素有排序功能、会存在多个相同的元素。

Set集合类型: 元素没有排序功能、不存在多个相同元素

该Sort Set是两种类型(listset)的集中体现,称为排序集合类型。

Sort Set类型:元素有排序功能、不存在多个相同元素

set一样sorted set也是string类型元素的集合,

不同的是每个元素都会关联一个

通过权/值可以有序的获取集合中的元素

权:一个集合中多个元素做排序的标准

值:元素的具体信息。

Sort set类型适合场合:

获得最热门(回复量)前5个帖子信息

 

select * from message order by backnum desc limit 5;

 

(以上需求可以通过简单sql语句实现,但是sql语句比较耗费mysql数据库资源  [或者是全部记录受到影响被查询   或者 是建立索引消耗额外资源])

案例:利用sort set实现获取最热门的前5帖子信息

 

排序集合中的每个元素都是的组合

(之前的set集合类型每个元素就只是一个 )

 

 

我们只做一个sort set排序集合,里边只保留5个元素信息,该5个元素是回复量最高的

 

每个帖子被回复的时候,都有机会进入该集合里边,但是只有回复量最高的前5个帖子会存在于在集合,回复量低的就被删除。

 

序号 命令及描述

1 ZADD key score1 member1 [score2 member2] 

向有序集合添加一个或多个成员,或者更新已存在成员的分数

 

2 ZCARD key 

获取有序集合的成员数

 

3 ZCOUNT key min max 

计算在有序集合中指定区间分数的成员数

 

4 ZINCRBY key increment member 

有序集合中对指定成员的分数加上增量 increment

 

5 ZINTERSTORE destination numkeys key [key ...] 

计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中

 

6 ZLEXCOUNT key min max 

在有序集合中计算指定字典区间内成员数量

 

7 ZRANGE key start stop [WITHSCORES] 

通过索引区间返回有序集合成指定区间内的成员

 

8 ZRANGEBYLEX key min max [LIMIT offset count] 

通过字典区间返回有序集合的成员

 

9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 

通过分数返回有序集合指定区间内的成员

 

10 ZRANK key member 

返回有序集合中指定成员的索引

 

11 ZREM key member [member ...] 

移除有序集合中的一个或多个成员

 

12 ZREMRANGEBYLEX key min max 

移除有序集合中给定的字典区间的所有成员

 

13 ZREMRANGEBYRANK key start stop 

移除有序集合中给定的排名区间的所有成员

 

14 ZREMRANGEBYSCORE key min max 

移除有序集合中给定的分数区间的所有成员

 

15 ZREVRANGE key start stop [WITHSCORES] 

返回有序集中指定区间内的成员,通过索引,分数从高到底

 

16 ZREVRANGEBYSCORE key max min [WITHSCORES] 

返回有序集中指定分数区间内的成员,分数从高到低排序

 

17 ZREVRANK key member 

返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序

 

18 ZSCORE key member 

返回有序集中,成员的分数值

 

19 ZUNIONSTORE destination numkeys key [key ...] 

计算给定的一个或多个有序集的并集,并存储在新的 key 中

 

20 ZSCAN key cursor [MATCH pattern] [COUNT count] 

迭代有序集合中的元素(包括元素成员和元素分值)

 

实例

 

 

文章来源: hiszm.blog.csdn.net,作者:孙中明,版权归原作者所有,如需转载,请联系作者。

原文链接:hiszm.blog.csdn.net/article/details/79775194

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。