這一篇文章將講述Redis中的sortedset類型命令,一樣也是經過demo來說述,其餘部分這裏就不在贅述了。java
項目Github地址:https://github.com/rainbowda/learnWay/tree/master/learnRedis/case-sortedsetgit
demo功能是文章點贊排名等等,整個demo的大體頁面以下。github
首先定義一個存儲文章的keyredis
private static final String ZSET_KEY = "articleList";
redis操做對象spring
private RedisTemplate redisTemplate; //string 命令操做對象 private ValueOperations valueOperations; //zset 命令操做對象 private ZSetOperations zSetOperations;
sortedset在Redis中的結構能夠看下圖(圖片來源於Redis in Action)。 app
@RequestMapping(value = "/getList/{sortType}", method = RequestMethod.GET) public Set getList(@PathVariable String sortType) { //若是沒有數據,則添加10條數據 if (zSetOperations.size(ZSET_KEY) == 0){ for (int i = 1; i <= 10; i++) { zSetOperations.add(ZSET_KEY,"文章:"+i, (int)(Math.random()*10+i)); } } //ASC根據分數從小到大排序,DESC反之 if ("ASC".equals(sortType)){ return zSetOperations.rangeWithScores(ZSET_KEY, 0, -1); } else { return zSetOperations.reverseRangeWithScores(ZSET_KEY, 0, -1); } }
這裏爲了省去一個個添加數據的麻煩,就在獲取列表數據中加了個判斷。當文章數據爲0時,默認添加10條數據,設置隨機score加上所在的索引。
而後根據url中的參數sortType來決定返回的數據是按照分數升序仍是降序排序。功能效果以下
dom
命令 | 用例 | 描述 | |
---|---|---|---|
ZADD | ZADD key [NX\ | XX][CH] [INCR] score member [score member ...] | 將全部指定成員添加到鍵爲key 有序集合(sorted set)裏面 |
ZRANGE | ZRANGE key start stop [WITHSCORES] | 返回有序集key中,指定區間內的成員。其中成員的位置按score值遞減(從小到大)來排列。 | |
ZREVRANGE | ZREVRANGE key start stop [WITHSCORES] | 返回有序集key中,指定區間內的成員。其中成員的位置按score值遞減(從大到小)來排列。 |
java代碼以下學習
@RequestMapping(value = "/star", method = RequestMethod.POST) public boolean starOrUnStar(String member, String type) { if ("UP".equals(type)){ zSetOperations.incrementScore(ZSET_KEY, member, 1); } else { zSetOperations.incrementScore(ZSET_KEY, member, -1); } return true; }
根據type決定是否加減分數,當type爲UP時表示贊,爲其餘(DOWN)時表示踩。功能效果以下
url
命令 | 用例 | 描述 |
---|---|---|
ZINCRBY | ZINCRBY key increment member | 爲有序集key的成員member的score值加上增量increment |
java代碼以下spa
@RequestMapping(value = "/rank/{type}/{member}", method = RequestMethod.GET) public Long rank(@PathVariable String member, @PathVariable String type) { Long rank = null; if ("ASC".equals(type)){ rank = zSetOperations.rank(ZSET_KEY, member); } else { rank = zSetOperations.reverseRank(ZSET_KEY, member); } return rank; }
根據type決定是升序排名仍是降序排名,若是是ASC則調用rank方法獲取升序排名,其餘則調用reverseRank獲取降序排名。與下方redis命令相似
ZRANK articleList "文章1" ZREVRANK articleList "文章1"
頁面效果圖以下
命令 | 用例 | 描述 |
---|---|---|
ZRANK | ZRANK key member | 返回有序集key中成員member的排名。其中有序集成員按score值遞增(從小到大)順序排列。排名以0爲底,也就是說,score值最小的成員排名爲0。 |
ZREVRANK | ZREVRANK key member | 返回有序集key中成員member的排名,其中有序集成員按score值從大到小排列。 |
命令 | 用例 | 描述 |
---|---|---|
ZCARD | ZCARD key | 返回key的有序集元素個數。 |
ZCOUNT | ZCOUNT key min max | 返回有序集key中,score值在min和max之間(默認包括score值等於min或max)的成員個數。 |
ZLEXCOUNT | ZLEXCOUNT key min max | 用於計算有序集合中指定成員之間的成員數量。 |
ZSCORE | ZSCORE key member | 返回有序集key中,成員member的score值。 |
返回key的有序集元素個數。
ZCARD key
返回值:key存在的時候,返回有序集的元素個數,不然返回0。
redis客戶端執行的命令以下
zadd zCardKey 1 one zcard zCardKey
下面是java代碼
@Test public void zCard() { jedis.zadd("zCardKey",1, "one"); jedis.zadd("zCardKey",2, "two"); System.out.println(jedis.zcard("zCardKey")); System.out.println(zSetOperations.size("zCardKey")); }
返回有序集key中,score值在min和max之間(默認包括score值等於min或max)的成員數量。
ZCOUNT key min max
返回值:指定分數範圍的元素個數。
redis客戶端執行的命令以下
zadd zCountKey 1 one 2 two 3 three 4 four zcount zCountKey 2 3
執行結果以下
下面是java代碼
@Test public void zCount() { jedis.zadd("zCountKey",1, "one"); jedis.zadd("zCountKey",2, "two"); jedis.zadd("zCountKey",3, "three"); jedis.zadd("zCountKey",4, "four"); System.out.println(jedis.zcount("zCountKey",2, 3)); System.out.println(zSetOperations.count("zCountKey",2, 3)); }
計算有序集合中指定成員之間的成員數量(按成員字典正序排序),可使用 - 和 + 表示score最小值和最大值
ZLEXCOUNT key min max
redis客戶端執行的命令以下
ZADD zLexCountKey 2 "b" 1 "a" 3 "c" 5 "e" 4 "d" ZLEXCOUNT zLexCountKey - + ZLEXCOUNT zLexCountKey [b [d
執行結果以下
下面是java代碼
@Test public void zLexCount() { zSetOperations.add("zLexCountKey", "b", 2); zSetOperations.add("zLexCountKey", "a", 1); zSetOperations.add("zLexCountKey", "c", 3); zSetOperations.add("zLexCountKey", "e", 5); zSetOperations.add("zLexCountKey", "d", 4); System.out.println(jedis.zlexcount("zLexCountKey", "-", "+")); System.out.println(jedis.zlexcount("zLexCountKey", "[b", "[d")); }
返回有序集key中,成員member的score值。
ZSCORE key member
返回值:成員member的score值
redis客戶端執行的命令以下
zadd zScoreKey 1 one ZSCORE zScoreKey one
下面是java代碼
@Test public void zScore() { jedis.zadd("zScoreKey",1, "one"); System.out.println(jedis.zscore("zScoreKey", "one")); System.out.println(zSetOperations.score("zScoreKey", "one")); }
命令 | 用例 | 描述 |
---|---|---|
ZRANGEBYLEX | ZRANGEBYLEX key min max [LIMIT offset count] |
返回指定成員區間內的成員,按成員字典正序排序。 |
ZRANGEBYSCORE | ZRANGEBYSCORE key min max [WITHSCORES] `[LIMIT offset count]` |
返回全部符合score條件的成員 |
ZREVRANGEBYLEX | ZREVRANGEBYLEX key max min [LIMIT offset count] |
返回指定成員區間內的成員,按成員字典倒序排序。 |
ZREVRANGEBYSCORE | ZREVRANGEBYSCORE key max min [WITHSCORES] `[LIMIT offset count]` |
返回有序集合中指定分數區間內的成員,分數由高到低排序。 |
ZSCAN | ZSCAN key cursor [MATCH pattern] `[COUNT count]` |
請參考 SCAN |
返回指定成員區間內的成員,按成員字典正序排序。https://redis.io/commands/zra...
ZRANGEBYLEX key min max [LIMIT offset count]
返回值:指定成員範圍的元素列表。
redis客戶端執行的命令以下
ZADD zRangeByLexKey 0 ba 0 a 0 ab 0 aa 0 b ZRANGEBYLEX zRangeByLexKey - + ZRANGEBYLEX zRangeByLexKey [aa (ba
執行結果以下
下面是java代碼
@Test public void zRangeByLex() { zSetOperations.add("zRangeByLexKey", "ba", 0); zSetOperations.add("zRangeByLexKey", "a", 0); zSetOperations.add("zRangeByLexKey", "ab", 0); zSetOperations.add("zRangeByLexKey", "aa", 0); zSetOperations.add("zRangeByLexKey", "b", 0); System.out.println(jedis.zrangeByLex("zRangeByLexKey", "-", "+")); RedisZSetCommands.Range range = new RedisZSetCommands.Range(); range.gte("aa"); range.lt("ba"); System.out.println(zSetOperations.rangeByLex("zRangeByLexKey",range)); }
獲取score在範圍以內的數據。min和max能夠是-inf和+inf
ZRANGEBYSCORE key min max [WITHSCORES]
`[LIMIT offset count] `
redis客戶端執行的命令以下
ZADD zRangeByScoreKey 1 ba 2 a 3 ab 4 aa 5 b ZRANGEBYSCORE zRangeByScoreKey -inf +inf ZRANGEBYSCORE zRangeByScoreKey 2 4
執行結果以下
下面是java代碼
@Test public void zRangeByScore() { zSetOperations.add("zRangeByScoreKey", "ba", 1); zSetOperations.add("zRangeByScoreKey", "a", 2); zSetOperations.add("zRangeByScoreKey", "ab", 3); zSetOperations.add("zRangeByScoreKey", "aa", 4); zSetOperations.add("zRangeByScoreKey", "b", 5); System.out.println(jedis.zrangeByScore("zRangeByScoreKey", "-inf", "+inf")); RedisZSetCommands.Range range = new RedisZSetCommands.Range(); System.out.println(zSetOperations.rangeByScore("zRangeByScoreKey", 2, 4)); }
命令 | 用例 | 描述 |
---|---|---|
ZREM | ZREM key member [member ...] | 刪除有序集合中的成員 |
ZREMRANGEBYLEX | ZREMRANGEBYLEX key min max | 刪除名稱按字典由低到高排序成員之間全部成員 |
ZREMRANGEBYRANK | ZREMRANGEBYRANK key start stop | 移除有序集key中,指定排名(rank)區間內的全部成員。 |
ZREMRANGEBYSCORE | ZREMRANGEBYSCORE key min max | 移除有序集key中,全部score值介於min和max之間(包括等於min或max)的成員 |
ZREM key member [member ...]
返回值:有序集合中刪除的成員個數
redis客戶端執行的命令以下
ZADD zRemKey 1 "one" 2 "two" 3 "three" ZREM zRemKey one ZRANGE zRemKey 0 -1
執行結果以下
下面是java代碼
@Test public void zRem() { zSetOperations.add("zRemKey", "one", 1); zSetOperations.add("zRemKey", "two", 2); zSetOperations.add("zRemKey", "three", 3); //jedis.zrem("zRemKey", "one"); zSetOperations.remove("zRemKey", "one"); System.out.println(zSetOperations.range("zRemKey", 0 , -1)); }
命令 | 用例 | 描述 | ||
---|---|---|---|---|
ZINTERSTORE | ZINTERSTORE destination numkeys key [key ...] `[WEIGHTS weight] [SUM\ |
MIN\ | MAX]` | 計算給定的numkeys個有序集合的交集,而且把結果放到destination中 |
ZUNIONSTORE | ZUNIONSTORE destination numkeys key [key ...] `[WEIGHTS weight] [SUM\ |
MIN\ | MAX]` | 計算給定的numkeys個有序集合的並集,而且把結果放到destination中 |
計算給定的numkeys個有序集合的交集,而且把結果放到destination中。
在給定要計算的key和其它參數以前,必須先給定key個數(numberkeys)。
默認狀況下,結果中一個元素的分數是有序集合中該元素分數之和,前提是該元素在這些有序集合中都存在。由於交集要求其成員必須是給定的每一個有序集合中的成員,結果集中的每一個元素的分數和輸入的有序集合個數相等。
對於WEIGHTS和AGGREGATE參數的描述,參見命令ZUNIONSTORE。
若是destination存在,就把它覆蓋。
ZINTERSTORE destination numkeys key [key ...]
[WEIGHTS weight [weight ...]]
[AGGREGATE SUM|MIN|MAX]
返回值:結果有序集合destination中元素個數。
redis客戶端執行的命令以下
ZADD zInterStoreKey1 1 "one" 2 "two" ZADD zInterStoreKey2 1 "one" 2 "two" 3 "three" ZINTERSTORE zInterStoreSumResult 2 zInterStoreKey1 zInterStoreKey2 WEIGHTS 2 3 ZRANGE zInterStoreSumResult 0 -1 WITHSCORES
執行結果以下
下面是java代碼
@Test public void zInterStore() { zSetOperations.add("zInterStoreKey1", "one", 1); zSetOperations.add("zInterStoreKey1", "two", 2); zSetOperations.add("zInterStoreKey2", "one", 1); zSetOperations.add("zInterStoreKey2", "two", 2); zSetOperations.add("zInterStoreKey2", "three", 3); ZParams zParams = new ZParams(); zParams.weightsByDouble(2, 3); zParams.aggregate(ZParams.Aggregate.SUM); jedis.zinterstore("zInterStoreSumResult", zParams, "zInterStoreKey1", "zInterStoreKey2"); printTuple("zInterStoreSumResult", jedis.zrangeWithScores("zInterStoreSumResult", 0, -1)); }
計算給定的numkeys個有序集合的並集,而且把結果放到destination中。
WEIGHTS參數至關於權重,默認就是1,能夠給不一樣的key設置不一樣的權重
AGGREGATE參數默認使用的參數SUM,還能夠選擇MIN或者MAX。這個參數決定結果集的score是取給定集合中的相加值、最小值仍是最大值
ZUNIONSTORE destination numkeys key [key ...]
[WEIGHTS weight [weight ...] ]
[AGGREGATE SUM|MIN|MAX]
redis客戶端執行的命令以下
ZADD zUnionStoreKey1 1 "one" 2 "two" ZADD zUnionStoreKey2 1 "one" 2 "two" 3 "three" ZUNIONSTORE zUnionStoreSumResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 ZUNIONSTORE zUnionStoreMinResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MIN ZUNIONSTORE zUnionStoreMaxResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MAX * ZRANGE zUnionStoreSumResult 0 -1 WITHSCORES ZRANGE zUnionStoreMinResult 0 -1 WITHSCORES ZRANGE zUnionStoreMaxResult 0 -1 WITHSCORES
執行結果以下
下面是java代碼
@Test public void zUnionStore() { zSetOperations.add("zUnionStoreKey1", "one", 1); zSetOperations.add("zUnionStoreKey1", "two", 2); zSetOperations.add("zUnionStoreKey2", "one", 1); zSetOperations.add("zUnionStoreKey2", "two", 2); zSetOperations.add("zUnionStoreKey2", "three", 3); ZParams zParams = new ZParams(); zParams.weightsByDouble(2, 3); zParams.aggregate(ZParams.Aggregate.SUM); jedis.zunionstore("zUnionStoreSumResult", zParams, "zUnionStoreKey1", "zUnionStoreKey2"); //求最小值 zParams.aggregate(ZParams.Aggregate.MIN); jedis.zunionstore("zUnionStoreMinResult", zParams, "zUnionStoreKey1", "zUnionStoreKey2"); //求最大值 zParams.aggregate(ZParams.Aggregate.MAX); jedis.zunionstore("zUnionStoreMaxResult", zParams, "zUnionStoreKey1", "zUnionStoreKey2"); //spring zSetOperations.unionAndStore("zUnionStoreKey1", "zUnionStoreKey2", "zUnionStoreResult"); printTuple("zUnionStoreSumResult", jedis.zrangeWithScores("zUnionStoreSumResult", 0, -1)); printTuple("zUnionStoreMinResult", jedis.zrangeWithScores("zUnionStoreMinResult", 0, -1)); printTuple("zUnionStoreMaxResult", jedis.zrangeWithScores("zUnionStoreMaxResult", 0, -1)); printTuple("zUnionStoreResult", jedis.zrangeWithScores("zUnionStoreResult", 0, -1)); }
仍是那句話建議學習的人最好每一個命令都去敲下,加深印象。
紙上得來終覺淺,絕知此事要躬行。————出自《冬夜讀書示子聿》