赞
踩
1.概念
应用:销量排行、积分排行、成绩排行,集合的value作为学号,成绩作为分数,插入集合的时候就已经排好顺序了。
2.赋值
向有序集合中添加一个或多个成员,或者更新已经存在的成员的分数
相关命令:127.0.0.1:6379> zadd user:4 1 白沙 4 万宝路
代码演示:
redisUtils.zadd(key, value, System.currentTimeMillis(), RedisConstants.datebase2);
- public Long zadd(String key, String value, double score, int index) {
- Jedis jedis = null;
- Long res = null;
- try {
- jedis = jedisPool.getResource();
- jedis.select(index);
- res = jedis.zadd(key, score, value);
- } catch (Exception e) {
- log.error(e.getMessage());
- } finally {
- close(jedis);
- }
- return res;
- }
效果:
3.取值
(1)获取有序集合的成员数量
相关命令:127.0.0.1:6379>
zcard user:5
"2"
代码演示:
Long size = redisUtils.zcard(key, RedisConstants.datebase2);
- public Long zcard(String key, int index) {
- Jedis jedis = null;
- Long res = null;
- try {
- jedis = jedisPool.getResource();
- jedis.select(index);
- res = jedis.zcard(key);
- } catch (Exception e) {
- log.error(e.getMessage());
- } finally {
- close(jedis);
- }
- return res;
- }
(2)计算有序集合中指定区间分数的成员数(返回value的个数)
相关命令:127.0.0.1:6379> zcount user:5 1 77
(integer) 1
代码演示:
Long sizes = redisUtils.zcount(key,0,-1);
- public Long zcount(String key, double min, double max) {
- Jedis jedis = null;
- try {
- jedis = jedisPool.getResource();
- return jedis.zcount(key, min, max);
- } catch (Exception e) {
-
- log.error(e.getMessage());
- return 0L;
- } finally {
- returnResource(jedisPool, jedis);
- }
-
- }
(3)返回有序集合指定成员的索引
相关命令:
127.0.0.1:6379> zrange user:5 0 -1 (正序,0,-1返回所有)
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrank user:5 金陵十二钗 (获取索引)
(integer) 1
(4)通过索引区间返回有序集合指定区间内的成员
相关命令:
127.0.0.1:6379>
zrange user:5 0 -1 (正序,0,-1返回所有)
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrevrange user:5 0 -1(倒序,0,-1返回所有)
1) "金陵十二钗"
2) "黄鹤楼"
(5)通过分数返回有序集合指定区间的成员
相关命令:
127.0.0.1:6379> zrangebyscore user:5 0 77
1) "黄鹤楼"
127.0.0.1:6379> zrangebyscore user:5 77 88
1) "黄鹤楼"
2) "金陵十二钗"
(6)返回索引
127.0.0.1:6379>zrank user:5 金陵十二钗
(integer) 1
4.删除
(1)移除集合
127.0.0.1:6379> del user:4
(integer) 1
127.0.0.1:6379> zrange z1 0 -1
(empty list or set)
(2)移除集合中的一个或多个成员
127.0.0.1:6379> zrange user:5 0 -1
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrem user:5 黄鹤楼
(integer) 1
127.0.0.1:6379> zrange user:5 0 -1
1) "金陵十二钗"
(3)移除有序集合中给定的排名区间的所有成员
127.0.0.1:6379> zadd user:4 1 白沙 4 万宝路
(integer) 2
127.0.0.1:6379> zremrangebyrank user:4 0 1
(integer) 2
127.0.0.1:6379> zrange user:4 0 -1
空
代码:
redisUtils.zremrangeByRank(key, 0, -1, RedisConstants.datebase2);
(4)根据分数区间删除
zadd user:4 1 白沙 4 万宝路 18 南京
127.0.0.1:6379> zrange user:4 0 -1
1) "白沙"
2) "万宝路"
3) "南京"
127.0.0.1:6379> zremrangebyscore user:4 1 5
(integer) 2
127.0.0.1:6379> zrange user:4 0 -1
1) "南京"
5、增加分数
(1)增加元素的分组,返回值是更改后的分数:
127.0.0.1:6379> zrange user:4 0 -1
1) "白沙"
2) "万宝路"
3) "南京"
127.0.0.1:6379> zincrby user:4 100 白沙
127.0.0.1:6379> zrange user:4 0 -1
1) "万宝路"
2) "南京"
3) "白沙"
小结:
zadd(key, score, member):向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
zrem(key, member) :删除名称为key的zset中的元素member
zincrby(key, increment, member) :如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment
zrank(key, member) :返回名称为key的zset(元素已按score从小到大排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”
zrevrank(key, member) :返回名称为key的zset(元素已按score从大到小排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”
zrange(key, start, end):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
zrevrange(key, start, end):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素
zrangebyscore(key, min, max):返回名称为key的zset中score >= min且score <= max的所有元素 zcard(key):返回名称为key的zset的基数,有几条数据
zscore(key, element):返回名称为key的zset中元素element的score
zremrangebyrank(key, min, max):删除名称为key的zset中rank >= min且rank <= max的所有元素 zremrangebyscore(key, min, max) :删除名称为key的zset中score >= min且score <= max的所有元素
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。