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小时
向名称为
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安装问题小结
- 使用 Redis 和 Python 构建一个共享单车的应用程序
- Redis偶发连接失败案例实战记录
- Redis中实现查找某个值的范围
- win 7 安装redis服务【笔记】
- redis的hGetAll函数的性能问题(记Redis那坑人的HGETALL)
- Redis和Memcached的区别详解
- Redis02 使用Redis数据库(String类型)全面解析
- 分割超大Redis数据库例子
- Redis总结笔记(一):安装和常用命令
- Redis sort 排序命令详解
- 用Redis实现微博关注关系
- Redis实现信息已读未读状态提示
- redis中修改配置文件中的端口号 密码方法
- 在Ruby on Rails上使用Redis Store的方法
- Redis和Memcache的区别总结
- 在Node.js应用中使用Redis的方法简介
- Redis服务器的启动过程分析
- web 应用中常用的各种 cache详解
- 利用yum安装Redis的方法详解