Redis 基本命令:SortedSet操作

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

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

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

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

SortedSet的数据结构类似于Set,不同的是Sorted中的每个成员都分配了一个值(Score)用于对其中的成员进行排序(升序)

1.zadd key score member[[score member] ..]

将一个或多个member及其socre加入到set中,socre须是float类型;例:zadd zsk 1 m1 2 m2 3 m3 0 m4在集合中是[m4 0][m3 3][m2 2][m1 1]这样的顺序

2.zcard key

返回有序集合中元素的个数,若key不存在返回0;例:zcard zsk。

3.zcount key min max

返回score值在min和max之间的元素个数(score和min之间是>=和max是<=),若min>max返回0,若min或max不为double类型返回error;例:zcount zsk 1 4。

4.zincrby key increment member

为集合成员member的score增加增量increment并返回新的score值,increment可以为负数但必须是double类型否则会返回error,若key不存在则会先新增member成员后再执行操作;例:zincrby zsk -1.1 m1。

5.zrange key start stop[withscores]

按索引返回key的成员区间,start和stop是有序集合的索引下标(从0开始),若stop

6.zrangebyscore key min max [withscores][limit offset count]

返回有序集合中score介于min和max之间的元素(若不想包含=请用如 zrangebyscore zsk (1 (4表示),litmit的功能类似于分页,例:zrangebyscore zsk 0 1 withscores limit 0 2返回:

7.zrank key member

返回有序集合中member的排名,排名以0为底;例:zrank zsk m4。

8.zrem key member[member…]

移除有序集合中的一个或多个元素,若member不存在则忽略;例:zrem zsk m5 m1。

9.zremrangebyrank key start stop

删除指定区间中的元素,start和stop的计数从0开始,start的位置须小于stop,start和stop也可为负数表示从后记位如-1表示倒数第一个元素;例:zremrangebyrank zsk 0 -3。

10.zremrangebyscore key min max

删除score值在min和max之间的元素(若不想包含=请用如 zremrangebyscore zsk (1 (4表示);例:zremrangebyscore zsk 1 2。

11.zrevrange key start stop[withscores]

和zrange类似,不过zrevrange的元素时倒序排列的:zrevrange zsk 0 5 withscores。

12.zrevrangebyscore key max min [withscores] [limit offset count]

和zrangebyscore类似,只不过返回结果是按倒序排列(这里需要注意一下max和min的书序),例:zrevrangebyscore zsk 6 2 withscores limit 1 2。

13.zrevrank key member

和zrank类似,不过数据返回的顺序为倒序,顺序以0位底,也就是说最大的排名为0,例:zrevrank zsk m6。

14.zscore key member

 返回成员member的score值,若key不存在返回nil;例:zscore zsk m3。
 

15.zunionstore destination numkeys key [key …] [weights [weight …]] [aggregate sum|min|max]

这个是返回一个或多个集合的并集并将结果存储到destination中去,若destination已存在此元素则score的值会被覆盖:
  numkeys用于指定key的数量,若key的数目和numkeys不一致会返回错误,score为元素的score之和,也就是说若sk1和sk2中都有m4,一个score为1另外一个为2,那么合并的新集合中score为3;
  weights为每个有序集合的乘法因子,也就是说sk1中和sk2中都有m4,score分别为1和2,乘法因子设置为1和2,那么最终的score为1*1+2*2,weights默认为1一旦显示指定weights那么weight的数目必须与key的数目相同否则会返回error;
  aggregate可以指定结果集的聚合方式,默认使用sum将某个成员之和作为score值,使用min使用最小的,使用max使用最大的,如sk1和sk2中m4的score分别为1和2,那么使用sum最终的socre就为3,使用max最终的socre就为2,使用min最总的score就为1,aggregate的会先计算weight再做比较。
  例:zunionstore zsk2 2 zsk zsk1 weights 1 4 aggregate max。

16.zinterstore destination numkeys key [key …] [WEIGHTS weight [weight …]] [AGGREGATE SUM|MIN|MAX]

取交集并存入destination,不想再细说了看zunionstore吧,例:zinterstore zsk2 2 zsk zsk1 weights 1 4 aggregate max

17.zscan key cursor[match pattern][count count]

增量迭代有序集合,参见scan,例:zscan sk 0 match *5 count 1。

参考:http://www.runoob.com/redis/redis-sorted-sets.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值