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"