1、Zset概念
Zset有序集合(sorted set):
- 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员即元素唯一!
- 每个元素都会关联一个double类型的分数(score),redis正是通过这些分数(score)对集合中的元素进行排序。
- 有序集合的元素是唯一的,但分数(score)却可以重复。
- 集合中最大的元素数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个元素)。
2、Zset语法
- Zadd key score1 member1 [score2 member2]
# 向有序集合添加一个或多个成员,或者更新已存在成员的分数 - Zrange key start stop [withscores]
# 通过索引区间内返回有序集合指定区间内的成员
- start 和 stop 分别代表index的下标。
- withscores结果带上score值。
- Zcard key
# 获取有序集合的成员数 - Zrem key member[member…]
#移除有序集合中的一个或多个成员 - Zcount key min max
# 计算在有序集合中指定分数区间的成员数 - Zincrby key increment member
# 有序集合中指定成员的分数加上增量 increment - Zrangebylex key min max [LIMIT offset count]
#通过字典区间返回有序集合的成员 - Zrank key member
# 返回有序集中指定成员的排名。 其中有序集成员按分数值递增(从小到大)顺序排列。 - Zrevrank key member [withscores]
# 返回有序集中指定成员的排名。其中有序集成员按分数值递减(从大到小)排序。 效果和Zrevrangebyscore一样 - Zrangebyscore key min max [withscores]
# 通过分数按照递增(从小到大)次序排列返回有序集合指定区间内的成员
- min max 代表score的值,Zrange 代表的是下标
- min max 可以搭配 闭区间 [小于等于或大于等于] 和 开区间 (小于或大于)
- Zrevrangebyscore key max min [withscores]
# 返回有序集中指定分数区间内的成员,分数从高到低排序
3、Zset在Jedis的示例
这里选择部分进行演示,其他命令可以通过查看源码进行操作!
public class TestZset {
public static void main(String[] args) {
Jedis jedis = new Jedis("localhost",6379);
jedis.auth("12345688");
HashMap<String, Double> scoreMap = new HashMap<String, Double>();
scoreMap.put("xiaoming",70.0);
scoreMap.put("xiaowang",100.0);
scoreMap.put("xiaohong",88.0);
scoreMap.put("xiaoli",60.0);
scoreMap.put("zhangsan",58.0);
jedis.zadd("math", scoreMap);
System.out.println("查看scoreMap的形式:"+scoreMap.toString());
System.out.println("返回math全部元素:"+jedis.zrange("math", 0, -1));
System.out.println("查看key有多少个元素:"+jedis.zcard("math"));
System.out.println("移除xiaoli 这个元素");
jedis.zrem("math", "xiaoli");
System.out.println("按照递增顺序,返回math全部的元素(含成绩):"+jedis.zrangeByScoreWithScores("math", "-inf", "inf"));
System.out.println("统计math集合,成绩在[80,100]之间的元素个数:"+jedis.zcount("math", 80,100 ));
}
}
结果演示:
|