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


相关推荐
hoiii1879 小时前
设置Redis在CentOS7上的自启动配置
数据库·redis·缓存
爬山算法9 小时前
Redis(122)Redis的版本更新如何进行?
数据库·redis·bootstrap
t***D2649 小时前
前端构建工具缓存策略,contenthash与chunkhash
前端·缓存
一 乐9 小时前
游戏助手|游戏攻略|基于SprinBoot+vue的游戏攻略系统小程序(源码+数据库+文档)
数据库·vue.js·spring boot·后端·游戏·小程序
kka杰10 小时前
MYSQL结构操作DDL指令1.数据库操作
数据库·mysql
TDengine (老段)10 小时前
TDengine 字符串函数 POSITION 用户手册
android·java·大数据·数据库·物联网·时序数据库·tdengine
wudl556610 小时前
Flink20 SQL 窗口函数概述
服务器·数据库·sql
Arva .10 小时前
MySQL 中的 MVCC
数据库·mysql
毕设十刻10 小时前
基于Vue的鲜花销售系统33n62(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
Boilermaker199210 小时前
【MySQL】数据目录与日志开篇
数据库·mysql