您的位置:首页 > 数据库 > Redis

redis之 zadd、zremrangebyscore、zremrangebyrank、zscore、zcard、zcount、zrangebyscore、zinczrevrankzrevrange

2016-08-15 23:20 447 查看
1.zadd

向名称为
key
的 zset
中添加元素 member,
score
用于排序。如果该元素已经存在,则根据
score
更新该元素的顺序
redis 127.0.0.1:6379>
zadd myzset 1 "one"
(integer) 1
redis 127.0.0.1:6379> zadd myzset 2 "two"
(integer) 1
redis 127.0.0.1:6379> zadd myzset 3 "two"
(integer) 0
redis 127.0.0.1:6379> zrange myzset 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "3"
redis 127.0.0.1:6379>
本例中我们向
myzset 中添加了
one 和
two,并且
two 被设置了
2 次,那么将以最后一次的
设置为准,最后我们将所有元素都显示出来并显示出了元素的
score。

2.zrem

删除名称为
key
的 zset
中的元素 member
redis 127.0.0.1:6379> zrange myzset 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "3"
redis 127.0.0.1:6379>
zrem myzset two
(integer) 1
redis 127.0.0.1:6379> zrange myzset 0 -1 withscores
1) "one"
2) "1"
redis 127.0.0.1:6379>
可以看到
two 被删除了

3.zincrby

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

向集合中添加该元素,其 score
的值为 increment

redis 127.0.0.1:6379> zadd myzset2 1 "one"

(integer) 1

redis 127.0.0.1:6379> zadd myzset2 2 "two"

(integer) 1

redis 127.0.0.1:6379> zincrby myzset2 2 "one"
"3"

redis 127.0.0.1:6379> zrange myzset2 0 -1 withscores

1) "two"

2) "2"

3) "one"

4) "3"

redis 127.0.0.1:6379>
本例中将 one
的 score 从
1 增加了 2,增加到了
3

4.zrevrank
返回名称为
key 的
zset 中
member 元素的排名(按
score
从大到小排序)即下标
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
7) "five"
8) "5"
redis 127.0.0.1:6379>
zrevrank myzset3 two
(integer) 2
redis 127.0.0.1:6379>
按从大到小排序的话
two 是第三个元素,下标是
2

5.zrevrange
返回名称为
key 的
zset( 按
score 从大到小排序)中的
index 从
start 到
end 的所有元素
redis 127.0.0.1:6379>
zrevrange myzset3 0 -1 withscores
1) "five"
2) "5"
3) "three"
4) "3"
5) "two"
6) "2"
7) "one"
8) "1"
redis 127.0.0.1:6379>
首先按
score 从大到小排序,再取出全部元素

6.zrangebyscore
返回集合中
score 在给定区间的元素
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
7) "five"
8) "5"
redis 127.0.0.1:6379>
zrangebyscore myzset3 2 3 withscores
1) "two"
2) "2"
3) "three"
4) "3"
redis 127.0.0.1:6379>
本例中,返回了
score 在
2~3 区间的元素

7.zcount
返回集合中
score 在给定区间的数量
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
7) "five"
8) "5"
redis 127.0.0.1:6379>
zcount myzset3 2 3
(integer) 2
redis 127.0.0.1:6379>
本例中,计算了
score 在
2~3 之间的元素数目

8.zcard
返回集合中元素个数
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
7) "five"
8) "5"
redis 127.0.0.1:6379>
zcard myzset3
(integer) 4
redis 127.0.0.1:6379>
从本例看出
myzset3 这个集全的元素数量是
4

9.zscore
返回给定元素对应的
score
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
7) "five"
8) "5"
redis 127.0.0.1:6379>
zscore myzset3 two
"2"
redis 127.0.0.1:6379>
此例中我们成功的将
two 的
score 取出来了。

10.zremrangebyrank
删除集合中排名在给定区间的元素
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
7) "five"
8) "5"
redis 127.0.0.1:6379>
zremrangebyrank myzset3 3 3
(integer) 1
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
redis 127.0.0.1:6379>
在本例中我们将
myzset3 中按从小到大排序结果的下标为
3 的元素删除了。

11.zremrangebyscore
删除集合中
score 在给定区间的元素
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "one"
2) "1"
3) "two"
4) "2"
5) "three"
6) "3"
redis 127.0.0.1:6379>
zremrangebyscore myzset3 1 2
(integer) 2
redis 127.0.0.1:6379> zrange myzset3 0 -1 withscores
1) "three"
2) "3"
redis 127.0.0.1:6379>
在本例中我们将
myzset3 中按从小到大排序结果的
score 在
1~2 之间的元素删除了。

超脑48小时 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  redis sorted set