ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Redis实现排行榜(带二位小数点)

2021-09-17 09:33:18  阅读:169  来源: 互联网

标签:String userId Redis 小数点 排行榜 add score public BigDecimal


public class UserRank {

    private String userId;

    private double score;
}


@RestController
@RequestMapping("rank")
public class RankController {

    @Autowired
    private RankService rankService;

    @GetMapping(value = "/add")
    public boolean add(String userId, double score){
        return rankService.add(userId, score);
    }

    @GetMapping(value = "/getRanks")
    public List<UserRank> getRanks(){
        return rankService.getRanks(0, 99);
    }

}


@Service
public class RankServiceImpl implements RankService {

    @Autowired
    private StringRedisTemplate redisTemplate;

    public static final String SCORE = "score";
    public static final BigDecimal tailDecimal = new BigDecimal(String.valueOf(1000000000000000d));
    public static final BigDecimal milsDecimal = new BigDecimal(String.valueOf(9999999999999d));

    @Override
    public boolean add(String userId, double score) {
        BigDecimal dealScore  = new BigDecimal(String.valueOf(score));
        dealScore = dealScore.multiply(tailDecimal).add(milsDecimal).subtract(new BigDecimal(String.valueOf(System.currentTimeMillis())));
        return redisTemplate.opsForZSet().add(SCORE, userId, dealScore.doubleValue());
    }

    @Override
    public List<UserRank> getRanks(int start, int end) {
        Set<ZSetOperations.TypedTuple<String>> scoreSet = redisTemplate.opsForZSet().reverseRangeWithScores(SCORE, start, end);
        List<UserRank> userRanks = new ArrayList<>(scoreSet.size());
        for (ZSetOperations.TypedTuple s : scoreSet) {
            userRanks.add(new UserRank(s.getValue().toString(), new BigDecimal(String.valueOf(s.getScore())).divide(tailDecimal).setScale(2, BigDecimal.ROUND_DOWN).doubleValue()));
        }
        return userRanks;
    }

添加

http://localhost:8080/rank/add?userId=1111&score=2497444.91

查看前百排行

http://localhost:8080/rank/getRanks

如果还要其他的数据 可以根据userId查询

标签:String,userId,Redis,小数点,排行榜,add,score,public,BigDecimal
来源: https://www.cnblogs.com/weiapro/p/15303261.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有