Redis的Zset在排行榜中应用

1.在pom文件导入:

java 复制代码
 <!-- redis -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-redis</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.session</groupId>
                <artifactId>spring-session-data-redis</artifactId>
            </dependency>

2.yml文件配置

java 复制代码
  redis:
    port: 6379
    host: localhost
    database: 5

3.代码:

java 复制代码
import java.util.Set;

@RestController
    @RequestMapping("/leaderboard")
    public class  testController {
    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    /**
     * 增加玩家分数
     * @param player
     * @param score
     */
     @PostMapping("/add")
    public void addPlayerScore(String player, double score) {
        stringRedisTemplate.opsForZSet().add("playerRanking", player, score);
    }

    /**
     * 获取前N名玩家排名
     * @param topN
     * @return
     */
    @GetMapping("/top")
    public Set<ZSetOperations.TypedTuple<String>> getPlayerRanking(int topN) {
        return stringRedisTemplate.opsForZSet().reverseRangeWithScores("playerRanking", 0, topN - 1);
    }

    /**
     * 获取玩家排名
     * @param player
     * @return
     */
    @GetMapping("/rank")
    public Long getPlayerRank(String player) {
        return stringRedisTemplate.opsForZSet().reverseRank("playerRanking", player) + 1;
    }


    /**
     * 对应的加分操作
     */
    @GetMapping("/increment")
    public void incrementScore(String player,double socre){
        stringRedisTemplate.opsForZSet().incrementScore("playerRanking",player,socre);
    }
}

4.插入数据:

java 复制代码
@SpringBootTest
public class test {
    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    @Test
    public void batchAddPlayers() {
        Random random = new Random();

        for (int i = 1; i <= 20; i++) {
            String player = "Player" + i; 
            double score = random.nextDouble() * 100; 
            stringRedisTemplate.opsForZSet().incrementScore("playerRanking",player,score);

        }
    }
}

5.结果:

![请添加图片描述](https://i-blog.csdnimg.cn/direct/ad2fa7880deb4f69a6754979711db20f.png


相关推荐
言之。2 分钟前
DDIA第四章 数据库存储引擎与索引技术深度解析
数据库·ddia
山沐与山7 分钟前
【Redis】读写锁实战详解:读多写少场景的性能优化利器
数据库·redis·性能优化
memgLIFE12 分钟前
SQL 优化方法详解(1)
java·数据库·sql
小宇的天下19 分钟前
Calibre 3Dstack--每日一个命令day 6 [process和export layout](3-6)
java·前端·数据库
自燃人~1 小时前
为什么MySQL用b+不用B数
数据库·mysql
做cv的小昊1 小时前
【TJU】信息检索与分析课程笔记和练习(6)英文数据库检索—web of science
大数据·数据库·笔记·学习·全文检索
严同学正在努力2 小时前
VMware安装银河麒麟V10操作系统X86_64全过程
数据库·鸿蒙系统·kylin
智源研究院官方账号2 小时前
众智FlagOS 1.6发布,以统一架构推动AI硬件、软件技术生态创新发展
数据库·人工智能·算法·架构·编辑器·硬件工程·开源软件
dishugj2 小时前
[SQLSERVER] Lock Waits/sec参数含义详解
数据库·oracle·sqlserver
我科绝伦(Huanhuan Zhou)2 小时前
Oracle锁等待深度解析:从理论到实战的全方位指南
数据库·oracle