redis zset类型

2017-04-26  本文已影响0人  鬭闢

sorted set 是 set 的一个升级版本,它在 set 的基础上增加了一个顺序属性,和 set 一样 sorted  set 也是 string 类型元素的集合,不同的是每个元素都会关联一个 double类型的 score。sorted set 最经常的使用方式应该是作为索引来使用.我们可以把要排序的字段作为 score 存储,对象的 id当元素存储。

1 zadd

向名称为 key 的 zset 中添加元素 member,score 用于排序。如果该元素已经存在,则根据

score 更新该元素的顺序

127.0.0.1:6379> zadd zset 1 hello

(integer) 1

127.0.0.1:6379> zadd zset 2 world

(integer) 1

跟新2次

127.0.0.1:6379> zadd zset 3 world

(integer) 0

元素和score一起显示

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "world"

4) "3"

2 zrem

删除名称为 key 的 zset 中的元素 member

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "world"

4) "3"

127.0.0.1:6379> zrem zset world

(integer) 1

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3 zincrby

如果在名称为 key 的 zset 中已经存在元素 member,则该元素的 score 增加 increment;否则向集合中添加该元素,其 score 的值为 increment

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "world"

4) "3"

127.0.0.1:6379> zincrby zset 2 wxc

"2"

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

4 zrank

返回名称为 key 的 zset 中 member 元素的排名(按 score 从小到大排序)即下标下标
下标下标!

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrank zset wxc

(integer) 1

5 zrevrank

返回名称为 key 的 zset 中 member 元素的排名(按 score 从大到小排序)即下标。与zrank相反。

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrevrank  zset hello

(integer) 2

6 zrevrange

返回名称为 key 的 zset(按 score 从大到小排序)中的 index 从 start 到 end 的所有元素

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrevrange zset 0 -1 withscores

1) "world"

2) "3"

3) "wxc"

4) "2"

5) "hello"

6) "1"

7 zrangebyscore

返回集合中 score 在给定区间的元素(score从1开始)

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zrangebyscore zset 2 4 withscores

1) "wxc"

2) "2"

3) "world"

4) "3"

8 zcount

返回集合中 score 在给定区间的数量

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zcount zset  2 3

(integer) 2

9 zcard

返回集合中元素个数

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zcard zset

(integer) 3

10 zscore

返回给定元素对应的 score

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zscore zset wxc

"2"

11 zremrangebyrank

删除集合中排名在给定下标区间的元素

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

5) "world"

6) "3"

127.0.0.1:6379> zremrangebyrank zset 2 2

(integer) 1

127.0.0.1:6379> zrange zset 0 -1 withscores

1) "hello"

2) "1"

3) "wxc"

4) "2"

12 zremrangebyscore

删除集合中 score 在给定区间的元素

13 zunionstore

ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

计算给定的一个或多个有序集的并集,其中给定key的数量必须以numkeys参数指定,并将该并集(结果集)储存到destination。默认情况下,结果集中某个成员的score值是所有给定集下该成员score值之

      weight选项

              使用WEIGHTS选项,你可以为每个给定有序集分别指定一个乘法因子(multiplication factor),每个给定有序集的所有成员的score值在传递给聚合函数(aggregation function)之前都要先乘以该有序集的因子。默认为1。

      aggregate选项

              使用aggregate选项,你可以指定并集的结果集的聚合方式。默认使用的参数sum,可以将所有集合中某个成员的score值之作为结果集中该成员的score值;使用参数min,可以将所有集合中某个成员的最小score值作为结果集中该成员的score值;而参数max则是将所有集合中某个成员的最大score值作为结果集中该成员的score值。

127.0.0.1:6379> zrange programmer 0 -1 withscores

1) "peter"

2) "2000"

3) "jack"

4) "3500"

5) "tom"

6) "5000"

127.0.0.1:6379> zrange manager 0 -1 withscores

1) "herry"

2) "2000"

3) "mary"

4) "3500"

5) "bob"

6) "4000"

127.0.0.1:6379> zunionstore salary1 2 programmer manager weights 2 3

(integer) 6

127.0.0.1:6379> zrange salary1 0 -1 withscores

1) "peter"

2) "4000"

3) "herry"

4) "6000"

5) "jack"

6) "7000"

7) "tom"

8) "10000"

9) "mary"

10) "10500"

11) "bob"

12) "12000"

13 zunionstore

14 zinterstore

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

计算给定的一个或多个有序集的交集,其中给定key的数量必须以numkeys参数指定,并将该交集(结果集)储存到destination。默认情况下,结果集中某个成员的score值是所有给定集下该成员score值之和.其余同zunionstore

上一篇 下一篇

猜你喜欢

热点阅读