redis - REIDS 排名问题, 取前后5名
怪我咯
怪我咯 2017-04-22 08:59:51
0
1
706

用 zAdd 加入排名

zAdd ranks 1000 老王
zAdd ranks 1001 如花
zAdd ranks 1002 死鱼
....

想取 用户老王及老王的前后各5名, 有没有简便方法?

谢谢。

怪我咯
怪我咯

走同样的路,发现不同的人生

Antworte allen (1)
黄舟

首先,获取老王的当前排名:ZRANK ranks 老王,假设老王的排名的第N名。

(我这里所说的前5名是指score比老王大的,后5名是score比老王小的)
那么老王的前5名是:ZRANGE ranks N+1 N+6,
老王的后5名是:ZRANGE ranks N-6 N-1

综合一下,前后加上老王自己就是:ZRANGE ranks N-6 N+6

注意:你要记得先判断N-6和N-1是否小于0

    Neueste Downloads
    Mehr>
    Web-Effekte
    Quellcode der Website
    Website-Materialien
    Frontend-Vorlage
    Über uns Haftungsausschluss Sitemap
    Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!