redis學習筆記3--sortSet
終于到最后一個數據結構了,加油!!
整體結構圖:
http://dl.iteye.com/upload/picture/pic/115995/0ee3789f-33e1-35ca-ac65-cbd6b4e4e147.jpg
?
?
1.ZADD
語法: ZADD key score value?
釋義:添加執行分數的value, score必須是double類型的數值
實踐:
redis 127.0.0.1:6379> zadd z1 1 a?
(integer) 1
redis 127.0.0.1:6379> zadd z1 2 b?
(integer) 1
redis 127.0.0.1:6379> zadd z1 20 bb?
(integer) 1
redis 127.0.0.1:6379> zadd z1 10 ff ?
(integer) 1
redis 127.0.0.1:6379> zrange z1 0 -1?
1) "a"
2) "b"
3) "ff"
4) "bb"
?
?
2.ZREM
語法:ZREM key value?
釋義:刪除指定value的值
實踐:
redis 127.0.0.1:6379> ZREM z1 b ? ? ? ? ? ?// 刪除,指定value
(integer) 1
redis 127.0.0.1:6379> zrange z1 0 -1 ? ? ? ??
1) "a"
2) "ff"
3) "bb"
?
?
3.ZCARD
語法:ZCARD key?
釋義:獲取集合總數
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1?
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zcard z1?
(integer) 3
?
4.ZCOUNT
語法:zcount key min max
釋義:計算在指定范圍內的元素數目
(1 6 ?==== 1 < x <= 6 ? ? ? ?// 括號代表開區間
1 6 ? ==== 1 <= x <= 6
?
?
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "a"
2) "1"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zcount z1 5 10 ? ? ?// 閉區間,能取得10
(integer) 1
redis 127.0.0.1:6379> zcount z1 5 (10 ? ? //開區間,無法得到10
(integer) 0
?
5.ZSCORE
語法:ZSCORE key value
釋義:獲取指定key的分數
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "a"
2) "1"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zscore z1 a ? ? ? ? ? ? // 獲取a的分數
"1"
?
6.ZINCRBY
語法:ZINCRBY key score value?
釋義:對于指定的value進行加法操作
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "a"
2) "1"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zincrby z1 10 a ? ? ? ? ? ?// 對于a+10
"11"
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "ff"
2) "10"
3) "a"
4) "11"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zincrby z1 -3 a ? ? ? ? ?// 對于a-3
"8"
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "a"
2) "8"
3) "ff"
4) "10"
5) "bb"
6) "20"
?
7.ZRANGE|ZREVRANGE
語法:ZRANGE|ZREVRANGE key?
釋義:顯示所有列表
redis 127.0.0.1:6379> zrange z1 0 -1?
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zrevrange z1 0 -1?
1) "bb"
2) "ff"
3) "a"
?
8.ZRANGEBYSCORE|ZREVRANGEBYSCORE
語法:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
釋義:獲取指定范圍內的數值
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "a"
2) "8"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zrangebyscore z1 -inf +inf ? // 在不清楚最大最小范圍的時間,可以采用這個 -inf +inf?
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zrangebyscore z1 8 10 ? ? ? // 閉區間
1) "a"
2) "ff"
redis 127.0.0.1:6379> zrangebyscore z1 (8 10 ? ? ?// 開區間
1) "ff"
?
?
9.ZRANK|ZREVRANK
語法:zrank|zremrank ?key member
釋義:獲取指定值在集合中的排名,以0代表第一位 。(順序或是逆序)
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "a"
2) "8"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zrank z1 a?
(integer) 0
redis 127.0.0.1:6379> zrank z1 ff //順序位置
(integer) 1?
redis 127.0.0.1:6379> zrevrank z1 a ? ? ? ?//逆序位置
(integer) 2
?
10.ZREMRANGEBYRANK
語法 :ZREMRANGEBYRANK key min max?
釋義:刪除指定下標的數據
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1?
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zremrangebyrank z1 0 1?
(integer) 2
redis 127.0.0.1:6379> zrange z1 0 -1?
1) "bb"
?
11.ZREMRANGEBYSCORE
語法 :ZREMRANGEBYSCORE key min max
釋義:根據指定分數刪除數據
實踐:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores?
1) "bb"
2) "20"
redis 127.0.0.1:6379> ZREMRANGEBYSCORE z1 -inf +inf ? ?// 刪除所有的數據 等同于 ?del z1
(integer) 1
redis 127.0.0.1:6379> zrange z1 0 -1?
(empty list or set)
?
12.ZINTERSTORE
語法:ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]
釋義:
? 計算給定的一個或多個有序集的交集,其中給定 key 的數量必須以 numkeys 參數指定,并將該交集(結果集)儲存到 destination 。
? 默認情況下,結果集中某個成員的 score 值是所有給定集下該成員 score 值之和.
?
實踐:
redis 127.0.0.1:6379> zrange s1 0 -1?
1) "a"
2) "b"
3) "c"
redis 127.0.0.1:6379> zrange s2 0 -1?
1) "a"
2) "c"
3) "d"
redis 127.0.0.1:6379> zinterstore s3 2 s1 s2?
(integer) 2
redis 127.0.0.1:6379> zrange s3 0 -1?
1) "a"
2) "c"
redis 127.0.0.1:6379>?
?
13.ZUNIONSTORE
語法:ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]
釋義:計算給定的一個或多個有序集的并集,其中給定 key 的數量必須以 numkeys 參數指定,并將該并集(結果集)儲存到 destination 。
默認情況下,結果集中某個成員的 score 值是所有給定集下該成員 score 值之 和 。
?
WEIGHTS
?使用 WEIGHTS 選項,你可以為 每個 給定有序集 分別 指定一個乘法因子(multiplication factor),每個給定有序集的所有成員的 score 值在傳遞給聚合函數(aggregation function)之前都要先乘以該有序集的因子。
?如果沒有指定 WEIGHTS 選項,乘法因子默認設置為 1 。
?
AGGREGATE
?使用 AGGREGATE 選項,你可以指定并集的結果集的聚合方式。
?默認使用的參數 SUM ,可以將所有集合中某個成員的 score 值之 和 作為結果集中該成員的 score 值;使用參數 MIN ,可以將所有集合中某個成員的 最小 score 值作為結果集中該成員的 score 值;而參數 MAX 則是將所有集合中某個成員的 最大 score 值作為結果集中該成員的 score 值。
?
實踐:
redis 127.0.0.1:6379> zunionstore s3 2 s1 s2?
(integer) 4
redis 127.0.0.1:6379> zrange s3 0 -1?
1) "b"
2) "a"
3) "c"
4) "d"
redis 127.0.0.1:6379>?
已有 0 人發表留言,猛擊->>這里<<-參與討論
ITeye推薦