Redis 有序集合和集合一樣也是string類型元素的集合,且不允許重複的成員。
不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來爲集合中的成員進行從小到大的排序。
有序集合的成員是唯一的,但分數(score)卻可以重複。
實例
127.0.0.1:6379> zadd only 1 redis
(integer) 1
127.0.0.1:6379> zadd only 2 mongodb
(integer) 1
127.0.0.1:6379> zadd only 3 mysql
(integer) 1
127.0.0.1:6379> zadd only 3 mysql
(integer) 0
127.0.0.1:6379> zadd only 4 mysql
(integer) 0
127.0.0.1:6379> zrange only 0 10
1) "redis"
2) "mongodb"
3) "mysql"
127.0.0.1:6379> zrange only 0 10 withscores
1) "redis"
2) "1"
3) "mongodb"
4) "2"
5) "mysql"
6) "4"
Redis 有序集合命令
1、ZADD key score1 member1 [score2 member2] 向有序集合添加一個或多個成員,或者更新已存在成員的分數
127.0.0.1:6379> zadd type 1 hadoop 2 scala 3 spark
(integer) 3
127.0.0.1:6379> zrange type 0 10 withscores
1) "hadoop"
2) "1"
3) "scala"
4) "2"
5) "spark"
6) "3"
2、ZCARD key 獲取有序集合的成員數
127.0.0.1:6379> zcard type
(integer) 3
3、ZCOUNT key min max 計算在有序集合中指定區間分數的成員數[min, max]
127.0.0.1:6379> zcount type 1 2
(integer) 2
4、ZINCRBY key increment member 有序集合中對指定成員的分數加上增量 increment
127.0.0.1:6379> zincrby type 4 hadoop
"5"
127.0.0.1:6379> zrange type 0 10 withscores
1) "scala"
2) "2"
3) "spark"
4) "3"
5) "hadoop"
6) "5"
5、ZINTERSTORE destination numkeys key [key ...] 計算給定的一個或多個有序集的交集並將結果集存儲在新的有序集合 key 中
127.0.0.1:6379> zadd abc 1 hadoop
(integer) 1
127.0.0.1:6379> zadd abc 2 spark
(integer) 1
127.0.0.1:6379> zadd abc 3 storm
(integer) 1
127.0.0.1:6379> zadd opq 1 hadoop
(integer) 1
127.0.0.1:6379> zadd opq 2 hive
(integer) 1
127.0.0.1:6379> zinterstore efg 2 abc opq
(integer) 1
127.0.0.1:6379> zrange efg 0 10
1) "hadoop"
6、ZLEXCOUNT key min max 在有序集合中計算指定字典區間內成員數量
7、ZRANGE key start stop [WITHSCORES] 通過索引區間返回有序集合成指定區間內的成員
127.0.0.1:6379> zrange abc 0 10 withscores
1) "hadoop"
2) "1"
3) "spark"
4) "2"
5) "storm"
6) "3"
8、ZRANGEBYLEX key min max [LIMIT offset count] 通過字典區間返回有序集合的成員
9、ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 通過分數返回有序集合指定區間內的成員
127.0.0.1:6379> zrangebyscore abc 1 3
1) "hadoop"
2) "spark"
3) "storm"
10、ZRANK key member 返回有序集合中指定成員的索引
127.0.0.1:6379> zrank abc hadoop
(integer) 0
127.0.0.1:6379> zrank abc spark
(integer) 1
11、ZREM key member [member ...] 移除有序集合中的一個或多個成員
127.0.0.1:6379> zrem abc hadoop
(integer) 1
127.0.0.1:6379> zrange abc 0 10
1) "spark"
2) "storm"
12、ZREMRANGEBYLEX key min max 移除有序集合中給定的字典區間的所有成員
13、ZREMRANGEBYRANK key start stop 移除有序集合中給定的排名區間的所有成員
127.0.0.1:6379> zremrangebyrank abc 0 2
(integer) 2
14、ZREMRANGEBYSCORE key min max 移除有序集合中給定的分數區間的所有成員
127.0.0.1:6379> zremrangebyscore opq 0 2
(integer) 2
15、ZREVRANGE key start stop [WITHSCORES] 返回有序集中指定區間內的成員,通過索引,分數從高到底
127.0.0.1:6379> zrevrange abc 0 10 withscores
1) "redis"
2) "3"
3) "java"
4) "2"
5) "hadoop"
6) "1"
16、ZREVRANGEBYSCORE key max min [WITHSCORES] 返回有序集中指定分數區間內的成員,分數從高到低排序
127.0.0.1:6379> zrevrangebyscore abc 10 0 withscores
1) "redis"
2) "3"
3) "java"
4) "2"
5) "hadoop"
6) "1"
17、ZREVRANK key member 返回有序集合中指定成員的排名,有序集成員按分數值遞減(從大到小)排序
127.0.0.1:6379> zrevrank abc java
(integer) 1
127.0.0.1:6379> zrevrank abc redis
(integer) 0
127.0.0.1:6379> zrevrank abc hadoop
(integer) 2
18、ZSCORE key member 返回有序集中,成員的分數值
127.0.0.1:6379> zscore abc hadoop
"1"
19、ZUNIONSTORE destination numkeys key [key ...] 計算給定的一個或多個有序集的並集,並存儲在新的 key 中
127.0.0.1:6379> zunionstore jj 2 abc opq
(integer) 3