REDIS批量获取hash key的数据

案例

由于用户信息是缓存在redis hash类型中的:
需求是获取一个用户列表,比如每一页30个用户,想一次性获取这30个用户的用户信息
可是redis并没有批量获取hash key的方法!

请问该如何解决?是不是设计有问题?
如用户 hash key 为 user:info:1 user:info:2 user:info:3 user:info:4…
这些hash key 存储着用户信息
想一次性获取 userinfo:1-30的hash值

解决方案:

eval "local rst={}; for i,v in pairs(KEYS) do rst[i]=redis.call('hgetall', v) end;return rst" 2 user:1 user:2

127.0.0.1:6379> hgetall user:2
1) "age"
2) "22"
3) "name"
4) "tom"

127.0.0.1:6379> hgetall user:1
1) "name"
2) "jack"
3) "age"
4) "21"

127.0.0.1:6379> eval "local rst={}; for i,v in pairs(KEYS) do rst[i]=redis.call('hgetall', v) end; return rst" 2 user:1 user:2
1) 1) "name"
   2) "jack"
   3) "age"
   4) "21"
2) 1) "age"
   2) "22"
   3) "name"
   4) "tom"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值