Java架构之Redis系列:通过文章点赞排名案例学习Sortedset命令

开发 后端 Redis
这一篇文章将讲述Redis中的sortedset类型命令,同样也是通过demo来讲述,其他部分这里就不在赘述了。

 前言

这一篇文章将讲述Redis中的sortedset类型命令,同样也是通过demo来讲述,其他部分这里就不在赘述了。

案例

demo功能是文章点赞排名等等,整个demo的大致页面如下。

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

准备工作

首先定义一个存储文章的key

  1. private static final String ZSET_KEY = "articleList"

redis操作对象

  1. private RedisTemplate redisTemplate; 
  2.  
  3. //string 命令操作对象 
  4.  
  5. private ValueOperations valueOperations; 
  6.  
  7. //zset 命令操作对象 
  8.  
  9. private ZSetOperations zSetOperations; 

sortedset在Redis中的结构可以看下图(图片来源于Redis in Action)。

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

列表查询

  1. @RequestMapping(value = "/getList/{sortType}", method = RequestMethod.GET) 
  2.  
  3. public Set getList(@PathVariable String sortType) { 
  4.  
  5. //如果没有数据,则添加10条数据 
  6.  
  7. if (zSetOperations.size(ZSET_KEY) == 0){ 
  8.  
  9. for (int i = 1; i <= 10; i++) { 
  10.  
  11. zSetOperations.add(ZSET_KEY,"文章:"+i, (int)(Math.random()*10+i)); 
  12.  
  13.  
  14.  
  15. //ASC根据分数从小到大排序,DESC反之 
  16.  
  17. if ("ASC".equals(sortType)){ 
  18.  
  19. return zSetOperations.rangeWithScores(ZSET_KEY, 0, -1); 
  20.  
  21. else { 
  22.  
  23. return zSetOperations.reverseRangeWithScores(ZSET_KEY, 0, -1); 
  24.  
  25.  

这里为了省去一个个添加数据的麻烦,就在获取列表数据中加了个判断。当文章数据为0时,默认添加10条数据,设置随机score加上所在的索引。

然后根据url中的参数sortType来决定返回的数据是按照分数升序还是降序排序。功能效果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

命令介绍

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

赞或踩

java代码如下

  1. @RequestMapping(value = "/star", method = RequestMethod.POST) 
  2.  
  3. public boolean starOrUnStar(String member, String type) { 
  4.  
  5. if ("UP".equals(type)){ 
  6.  
  7. zSetOperations.incrementScore(ZSET_KEY, member, 1); 
  8.  
  9. else { 
  10.  
  11. zSetOperations.incrementScore(ZSET_KEY, member, -1); 
  12.  
  13.  
  14. return true
  15.  

根据type决定是否加减分数,当type为UP时表示赞,为其他(DOWN)时表示踩。功能效果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

命令介绍

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

升降序排名

java代码如下

  1. @RequestMapping(value = "/rank/{type}/{member}", method = RequestMethod.GET) 
  2.  
  3. public Long rank(@PathVariable String member, @PathVariable String type) { 
  4.  
  5. Long rank = null
  6.  
  7. if ("ASC".equals(type)){ 
  8.  
  9. rank = zSetOperations.rank(ZSET_KEY, member); 
  10.  
  11. else { 
  12.  
  13. rank = zSetOperations.reverseRank(ZSET_KEY, member); 
  14.  
  15.  
  16. return rank; 
  17.  

根据type决定是升序排名还是降序排名,如果是ASC则调用rank方法获取升序排名,其他则调用reverseRank获取降序排名。与下方redis命令类似

  1. ZRANK articleList "文章1" 
  2.  
  3. ZREVRANK articleList "文章1" 

页面效果图如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

命令介绍

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

其他命令

获取属性

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

ZCARD命令

返回key的有序集元素个数。

ZCARD key

返回值:key存在的时候,返回有序集的元素个数,否则返回0。

redis客户端执行的命令如下

  1. zadd zCardKey 1 one 
  2. zcard zCardKey 

下面是java代码

  1. @Test 
  2.  
  3. public void zCard() { 
  4.  
  5. jedis.zadd("zCardKey",1, "one"); 
  6.  
  7. jedis.zadd("zCardKey",2, "two"); 
  8.  
  9. System.out.println(jedis.zcard("zCardKey")); 
  10.  
  11. System.out.println(zSetOperations.size("zCardKey")); 
  12.  

ZCOUNT命令

返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员数量。

ZCOUNT key min max

返回值:指定分数范围的元素个数。

redis客户端执行的命令如下

  1. zadd zCountKey 1 one 2 two 3 three 4 four 
  2. zcount zCountKey 2 3 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zCount() { 
  4.  
  5. jedis.zadd("zCountKey",1, "one"); 
  6.  
  7. jedis.zadd("zCountKey",2, "two"); 
  8.  
  9. jedis.zadd("zCountKey",3, "three"); 
  10.  
  11. jedis.zadd("zCountKey",4, "four"); 
  12.  
  13. System.out.println(jedis.zcount("zCountKey",2, 3)); 
  14.  
  15. System.out.println(zSetOperations.count("zCountKey",2, 3)); 
  16.  

ZLEXCOUNT命令

计算有序集合中指定成员之间的成员数量(按成员字典正序排序),可以使用 - 和 + 表示score最小值和最大值

ZLEXCOUNT key min max

redis客户端执行的命令如下

  1. ZADD zLexCountKey 2 "b" 1 "a" 3 "c" 5 "e" 4 "d" 
  2.  
  3. ZLEXCOUNT zLexCountKey - + 
  4.  
  5. ZLEXCOUNT zLexCountKey [b [d 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zLexCount() { 
  4.  
  5. zSetOperations.add("zLexCountKey""b", 2); 
  6.  
  7. zSetOperations.add("zLexCountKey""a", 1); 
  8.  
  9. zSetOperations.add("zLexCountKey""c", 3); 
  10.  
  11. zSetOperations.add("zLexCountKey""e", 5); 
  12.  
  13. zSetOperations.add("zLexCountKey""d", 4); 
  14.  
  15. System.out.println(jedis.zlexcount("zLexCountKey""-""+")); 
  16.  
  17. System.out.println(jedis.zlexcount("zLexCountKey""[b""[d")); 
  18.  

ZSCORE命令

返回有序集key中,成员member的score值。

ZSCORE key member

返回值:成员member的score值

redis客户端执行的命令如下

  1. zadd zScoreKey 1 one 
  2.  
  3. ZSCORE zScoreKey one 

下面是java代码

  1. @Test 
  2.  
  3. public void zScore() { 
  4.  
  5. jedis.zadd("zScoreKey",1, "one"); 
  6.  
  7. System.out.println(jedis.zscore("zScoreKey""one")); 
  8.  
  9. System.out.println(zSetOperations.score("zScoreKey""one")); 
  10.  

获取成员

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

ZRANGEBYLEX命令

返回指定成员区间内的成员,按成员字典正序排序。

https://redis.io/commands/zrangebylex

ZRANGEBYLEX key min max [LIMIT offset count]

返回值:指定成员范围的元素列表。

redis客户端执行的命令如下

  1. ZADD zRangeByLexKey 0 ba 0 a 0 ab 0 aa 0 b 
  2.  
  3. ZRANGEBYLEX zRangeByLexKey - + 
  4.  
  5. ZRANGEBYLEX zRangeByLexKey [aa (ba 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zRangeByLex() { 
  4.  
  5. zSetOperations.add("zRangeByLexKey""ba", 0); 
  6.  
  7. zSetOperations.add("zRangeByLexKey""a", 0); 
  8.  
  9. zSetOperations.add("zRangeByLexKey""ab", 0); 
  10.  
  11. zSetOperations.add("zRangeByLexKey""aa", 0); 
  12.  
  13. zSetOperations.add("zRangeByLexKey""b", 0); 
  14.  
  15. System.out.println(jedis.zrangeByLex("zRangeByLexKey""-""+")); 
  16.  
  17. RedisZSetCommands.Range range = new RedisZSetCommands.Range(); 
  18.  
  19. range.gte("aa"); 
  20.  
  21. range.lt("ba"); 
  22.  
  23. System.out.println(zSetOperations.rangeByLex("zRangeByLexKey",range)); 
  24.  

ZRANGEBYSCORE命令

获取score在范围之内的数据。min和max可以是-inf和+inf

ZRANGEBYSCORE key min max [WITHSCORES]``[LIMIT offset count]

redis客户端执行的命令如下

  1. ZADD zRangeByScoreKey 1 ba 2 a 3 ab 4 aa 5 b 
  2.  
  3. ZRANGEBYSCORE zRangeByScoreKey -inf +inf 
  4.  
  5. ZRANGEBYSCORE zRangeByScoreKey 2 4 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zRangeByScore() { 
  4.  
  5. zSetOperations.add("zRangeByScoreKey""ba", 1); 
  6.  
  7. zSetOperations.add("zRangeByScoreKey""a", 2); 
  8.  
  9. zSetOperations.add("zRangeByScoreKey""ab", 3); 
  10.  
  11. zSetOperations.add("zRangeByScoreKey""aa", 4); 
  12.  
  13. zSetOperations.add("zRangeByScoreKey""b", 5); 
  14.  
  15. System.out.println(jedis.zrangeByScore("zRangeByScoreKey""-inf""+inf")); 
  16.  
  17. RedisZSetCommands.Range range = new RedisZSetCommands.Range(); 
  18.  
  19. System.out.println(zSetOperations.rangeByScore("zRangeByScoreKey", 2, 4)); 
  20.  

移除相关命令

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

ZREM命令

ZREM key member [member ...]

返回值:有序集合中删除的成员个数

redis客户端执行的命令如下

  1. ZADD zRemKey 1 "one" 2 "two" 3 "three" 
  2.  
  3. ZREM zRemKey one 
  4.  
  5. ZRANGE zRemKey 0 -1 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zRem() { 
  4.  
  5. zSetOperations.add("zRemKey""one", 1); 
  6.  
  7. zSetOperations.add("zRemKey""two", 2); 
  8.  
  9. zSetOperations.add("zRemKey""three", 3); 
  10.  
  11. //jedis.zrem("zRemKey""one"); 
  12.  
  13. zSetOperations.remove("zRemKey""one"); 
  14.  
  15. System.out.println(zSetOperations.range("zRemKey", 0 , -1)); 
  16.  

交并集

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

ZINTERSTORE命令

计算给定的numkeys个有序集合的交集,并且把结果放到destination中。

在给定要计算的key和其它参数之前,必须先给定key个数(numberkeys)。

默认情况下,结果中一个元素的分数是有序集合中该元素分数之和,前提是该元素在这些有序集合中都存在。因为交集要求其成员必须是给定的每个有序集合中的成员,结果集中的每个元素的分数和输入的有序集合个数相等。

对于WEIGHTS和AGGREGATE参数的描述,参见命令ZUNIONSTORE。

如果destination存在,就把它覆盖。

ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]

返回值:结果有序集合destination中元素个数。

redis客户端执行的命令如下

  1. ZADD zInterStoreKey1 1 "one" 2 "two" 
  2.  
  3. ZADD zInterStoreKey2 1 "one" 2 "two" 3 "three" 
  4.  
  5. ZINTERSTORE zInterStoreSumResult 2 zInterStoreKey1 zInterStoreKey2 WEIGHTS 2 3 
  6.  
  7. ZRANGE zInterStoreSumResult 0 -1 WITHSCORES 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zInterStore() { 
  4.  
  5. zSetOperations.add("zInterStoreKey1""one", 1); 
  6.  
  7. zSetOperations.add("zInterStoreKey1""two", 2); 
  8.  
  9. zSetOperations.add("zInterStoreKey2""one", 1); 
  10.  
  11. zSetOperations.add("zInterStoreKey2""two", 2); 
  12.  
  13. zSetOperations.add("zInterStoreKey2""three", 3); 
  14.  
  15. ZParams zParams = new ZParams(); 
  16.  
  17. zParams.weightsByDouble(2, 3); 
  18.  
  19. zParams.aggregate(ZParams.Aggregate.SUM); 
  20.  
  21. jedis.zinterstore("zInterStoreSumResult", zParams, "zInterStoreKey1""zInterStoreKey2"); 
  22.  
  23. printTuple("zInterStoreSumResult", jedis.zrangeWithScores("zInterStoreSumResult", 0, -1)); 
  24.  

ZUNIONSTORE命令

计算给定的numkeys个有序集合的并集,并且把结果放到destination中。

WEIGHTS参数相当于权重,默认就是1,可以给不同的key设置不同的权重

AGGREGATE参数默认使用的参数SUM,还可以选择MIN或者MAX。这个参数决定结果集的score是取给定集合中的相加值、最小值还是最大值

ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...] ] [AGGREGATE SUM|MIN|MAX]

redis客户端执行的命令如下

  1. ZADD zUnionStoreKey1 1 "one" 2 "two" 
  2.  
  3. ZADD zUnionStoreKey2 1 "one" 2 "two" 3 "three" 
  4.  
  5. ZUNIONSTORE zUnionStoreSumResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 
  6.  
  7. ZUNIONSTORE zUnionStoreMinResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MIN 
  8.  
  9. ZUNIONSTORE zUnionStoreMaxResult 2 zUnionStoreKey1 zUnionStoreKey2 WEIGHTS 2 3 AGGREGATE MAX 
  10.  
  11.  
  12. ZRANGE zUnionStoreSumResult 0 -1 WITHSCORES 
  13.  
  14. ZRANGE zUnionStoreMinResult 0 -1 WITHSCORES 
  15.  
  16. ZRANGE zUnionStoreMaxResult 0 -1 WITHSCORES 

执行结果如下

Java架构之redis系列:通过文章点赞排名案例学习sortedset命令

下面是java代码

  1. @Test 
  2.  
  3. public void zUnionStore() { 
  4.  
  5. zSetOperations.add("zUnionStoreKey1""one", 1); 
  6.  
  7. zSetOperations.add("zUnionStoreKey1""two", 2); 
  8.  
  9. zSetOperations.add("zUnionStoreKey2""one", 1); 
  10.  
  11. zSetOperations.add("zUnionStoreKey2""two", 2); 
  12.  
  13. zSetOperations.add("zUnionStoreKey2""three", 3); 
  14.  
  15. ZParams zParams = new ZParams(); 
  16.  
  17. zParams.weightsByDouble(2, 3); 
  18.  
  19. zParams.aggregate(ZParams.Aggregate.SUM); 
  20.  
  21. jedis.zunionstore("zUnionStoreSumResult", zParams, "zUnionStoreKey1""zUnionStoreKey2"); 
  22.  
  23. //求最小值 
  24.  
  25. zParams.aggregate(ZParams.Aggregate.MIN); 
  26.  
  27. jedis.zunionstore("zUnionStoreMinResult", zParams, "zUnionStoreKey1""zUnionStoreKey2"); 
  28.  
  29. //求最大值 
  30.  
  31. zParams.aggregate(ZParams.Aggregate.MAX); 
  32.  
  33. jedis.zunionstore("zUnionStoreMaxResult", zParams, "zUnionStoreKey1""zUnionStoreKey2"); 
  34.  
  35. //spring 
  36.  
  37. zSetOperations.unionAndStore("zUnionStoreKey1""zUnionStoreKey2""zUnionStoreResult"); 
  38.  
  39. printTuple("zUnionStoreSumResult", jedis.zrangeWithScores("zUnionStoreSumResult", 0, -1)); 
  40.  
  41. printTuple("zUnionStoreMinResult", jedis.zrangeWithScores("zUnionStoreMinResult", 0, -1)); 
  42.  
  43. printTuple("zUnionStoreMaxResult", jedis.zrangeWithScores("zUnionStoreMaxResult", 0, -1)); 
  44.  
  45. printTuple("zUnionStoreResult", jedis.zrangeWithScores("zUnionStoreResult", 0, -1)); 
  46.  
责任编辑:华轩 来源: 今日头条
相关推荐

2020-01-10 15:15:53

Redis点赞数据库

2020-12-03 11:00:29

Spring ClouRedis数据库

2020-05-11 17:00:30

点赞MySQLRedis

2018-02-24 11:11:02

Linux命令 文件系统

2009-09-22 13:10:22

ibmdwSOA

2015-07-17 10:41:59

点赞按钮

2021-08-10 15:37:34

鸿蒙HarmonyOS应用

2020-12-14 11:26:25

接口测试python

2018-01-02 11:55:59

Linux文件系统FSCK命令

2020-12-30 07:26:20

RedisSortedSet内存包

2017-06-07 14:58:39

Redis源码学习Redis事务

2020-12-08 12:24:55

接口测试Interface

2012-08-22 10:18:03

PHP

2011-06-02 10:28:18

2014-08-01 13:40:50

R语言

2016-09-18 19:07:33

Java值传递引用传递

2020-12-29 10:16:24

接口测试flaskmock

2016-09-21 14:17:11

JUnit架构API

2015-10-08 14:03:01

TCP网络协议

2018-05-10 16:47:10

戴尔
点赞
收藏

51CTO技术栈公众号