绝代码农 发表于 2021-7-30 18:58:53

Redis 有序集合(sorted set)

Redis 有序集合(sorted set)
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
list链表类型: 内部存储的元素有排序功能、会存在多个相同的元素。
Set集合类型: 元素没有排序功能、不存在多个相同元素
该Sort Set是两种类型(list和set)的集中体现,称为排序集合类型。
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  
向有序集合添加一个或多个成员,或者更新已存在成员的分数
2 ZCARD key 
获取有序集合的成员数
3 ZCOUNT key min max 
计算在有序集合中指定区间分数的成员数
4 ZINCRBY key increment member 
有序集合中对指定成员的分数加上增量 increment
5 ZINTERSTORE destination numkeys key  
计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
6 ZLEXCOUNT key min max 
在有序集合中计算指定字典区间内成员数量
7 ZRANGE key start stop  
通过索引区间返回有序集合成指定区间内的成员
8 ZRANGEBYLEX key min max  
通过字典区间返回有序集合的成员
9 ZRANGEBYSCORE key min max  
通过分数返回有序集合指定区间内的成员
10 ZRANK key member 
返回有序集合中指定成员的索引
11 ZREM key member  
移除有序集合中的一个或多个成员
12 ZREMRANGEBYLEX key min max 
移除有序集合中给定的字典区间的所有成员
13 ZREMRANGEBYRANK key start stop 
移除有序集合中给定的排名区间的所有成员
14 ZREMRANGEBYSCORE key min max 
移除有序集合中给定的分数区间的所有成员
15 ZREVRANGE key start stop  
返回有序集中指定区间内的成员,通过索引,分数从高到底
16 ZREVRANGEBYSCORE key max min  
返回有序集中指定分数区间内的成员,分数从高到低排序
17 ZREVRANK key member 
返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序
18 ZSCORE key member 
返回有序集中,成员的分数值
19 ZUNIONSTORE destination numkeys key  
计算给定的一个或多个有序集的并集,并存储在新的 key 中
20 ZSCAN key cursor  
迭代有序集合中的元素(包括元素成员和元素分值)
实例



文档来源:51CTO技术博客https://blog.51cto.com/hiszm/3198889
页: [1]
查看完整版本: Redis 有序集合(sorted set)