Redis基础——Order Set结构及操作命令

Order Set 有序集合

zadd key score1 value1 score2 value2   添加元素 score是排序的依据

127.0.0.1:6379> zadd friends 18 tom 19 jerry 7 lily 32 jack 29 mike
(integer) 5
127.0.0.1:6379> zrange friends 0 -1
1) "lily"
2) "tom"
3) "jerry"
4) "mike"
5) "jack"

zrem key value1 value2    删除集合中的元素

127.0.0.1:6379> zrem friends tom
(integer) 1
127.0.0.1:6379> zrem friends 29
(integer) 0
127.0.0.1:6379> zrange friends 0 -1
1) "lily"
2) "jerry"
3) "mike"
4) "jack"

zremrangebyscore key min max    按照socre来删除元素,删除score在[min,max]之间的

127.0.0.1:6379> zremrangebyscore friends 19 20
(integer) 1
127.0.0.1:6379> zrange friends 0 -1
1) "lily"
2) "mike"
3) "jack"

zremrangebyrank key start end   按排名删除元素,删除名次在[start,end]之间的

127.0.0.1:6379> zrange friends 0 -1
1) "lily"
2) "tom"
3) "mike"
4) "jack"
127.0.0.1:6379> zremrangebyrank friends 1 2
(integer) 2
127.0.0.1:6379> zrange friends 0 -1
1) "lily"
2) "jack"

zrank key member   查询member的排名(升续 0名开始)

127.0.0.1:6379> zrank friends lily
(integer) 0
127.0.0.1:6379> zrank friends mike
(integer) 1

zrevrank key memeber   查询 member的排名(降续 0名开始)

127.0.0.1:6379> zrevrank friends lily
(integer) 2
127.0.0.1:6379> zrevrank friends mike
(integer) 1

zrange key start stop [WITHSCORES]   把集合排序后,返回名次[start,stop]的元素  默认是升续排列   withscores 是把score也打印出来

127.0.0.1:6379> zrange friends 0 -1
1) "lily"
2) "tom"
3) "jerry"
4) "mike"
5) "jack"
127.0.0.1:6379> zrange friends 0 -1 withscores
 1) "lily"
 2) "7"
 3) "tom"
 4) "18"
 5) "jerry"
 6) "19"
 7) "mike"
 8) "29"
 9) "jack"
10) "32"

zrevrange key start stop    把集合降序排列,取名字[start,stop]之间的元素

127.0.0.1:6379> zrevrange friends 0 -1
1) "jack"
2) "mike"
3) "jerry"
4) "tom"
5) "lily"
127.0.0.1:6379> zrevrange friends 0 -1 withscores
 1) "jack"
 2) "32"
 3) "mike"
 4) "29"
 5) "jerry"
 6) "19"
 7) "tom"
 8) "18"
 9) "lily"
10) "7"

zrangebyscore key min max [withscores] limit offset N   集合(升续)排序后,取score在[min,max]内的元素,并跳过 offset个, 取出N个

127.0.0.1:6379> zrevrange friends 0 -1 withscores
 1) "jack"
 2) "32"
 3) "mike"
 4) "29"
 5) "jerry"
 6) "19"
 7) "tom"
 8) "18"
 9) "lily"
10) "7"
127.0.0.1:6379> zrangebyscore friends 1 100 withscores limit 1 2
1) "tom"
2) "18"
3) "jerry"

zcard key   返回元素个数

127.0.0.1:6379> zcard friends
(integer) 5

zcount key min max   返回[min,max] 区间内元素的数量

127.0.0.1:6379> zcount friends 1 22
(integer) 3

zinterstore destination numkeys key1 [key2 ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]   

求key1,key2的交集,key1,key2的权重分别是 weight1,weight2
聚合方法用: sum |min|max
聚合的结果,保存在dest集合内
注意: weights ,aggregate如何理解?
答: 如果有交集, 交集元素又有socre,score怎么处理?
 Aggregate sum->score相加   , min 求最小score, max 最大score

另: 可以通过weigth设置不同key的权重, 交集时,socre * weights
redis 127.0.0.1:6379> zadd z1 2 a 3 b 4 c
(integer) 3
redis 127.0.0.1:6379> zadd z2 2.5 a 1 b 8 d
(integer) 3
redis 127.0.0.1:6379> zinterstore tmp 2 z1 z2
(integer) 2
redis 127.0.0.1:6379> zrange tmp 0 -1
1) "b"
2) "a"
redis 127.0.0.1:6379> zrange tmp 0 -1 withscores
1) "b"
2) "4"
3) "a"
4) "4.5"
redis 127.0.0.1:6379> zinterstore tmp 2 z1 z2 aggregate sum
(integer) 2
redis 127.0.0.1:6379> zrange tmp 0 -1 withscores
1) "b"
2) "4"
3) "a"
4) "4.5"
redis 127.0.0.1:6379> zinterstore tmp 2 z1 z2 aggregate min
(integer) 2
redis 127.0.0.1:6379> zrange tmp 0 -1 withscores
1) "b"
2) "1"
3) "a"
4) "2"
redis 127.0.0.1:6379> zinterstore tmp 2 z1 z2 weights 1 2
(integer) 2
redis 127.0.0.1:6379> zrange tmp 0 -1 withscores
1) "b"
2) "5"
3) "a"
4) "7"

转载于:https://my.oschina.net/u/3906795/blog/1926514

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值