gpt4 book ai didi

javascript - Redis,带分页的排序集

转载 作者:可可西里 更新时间:2023-11-01 11:11:46 25 4
gpt4 key购买 nike

我目前在Redis中有如下数据结构

client.hmset('user:' + user.id, 'id', user.id, 'user', JSON.stringify(meta));
client.zadd(['user:user_by_created_time', meta.created_time, 'user:' + user.id]);
client.zadd(['user:user_by_age', meta.age, 'user:' + user.id]);

然后我什么时候让前 10 个用户按年龄排序,当超过 10 个时,我应该能够传递一个允许我使用分页的 offset

我目前拥有的是以下内容

client.zrangebyscore(['user:user_by_age', '-inf', '+inf'], (err, results) => {
const multi = client.multi();
results.forEach(result => {
multi.hgetall(result);
});

multi.exec((err, results) => { ... });
});

我对如何继续这个问题有点困惑,我知道可以对列表进行排序,但我无法弄清楚如何在特定偏移量后仅获得 10 个用户。

我正在使用 Node Redis 客户端:https://github.com/NodeRedis/node_redis

最佳答案

要对已排序的集合进行分页,请使用 ZRANGE ,而不是 ZRANGEBYSCORE。参数是排名,因此要获得前 10 个用户,请使用 ZRANGE user:user_by_age 0 9,要获得接下来的 10 个用户,请使用 ZRANGE user:user_by_age 10 19,等等

关于javascript - Redis,带分页的排序集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40098207/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com