对项目进行循环并同步访问每个元素并不是很有效。使用 Redis 2.4,有多种方法可以做你想做的事:
- 通过使用排序命令
- 通过使用流水线
- 通过使用可变参数命令
使用 Redis 2.6,您还可以使用 Lua 脚本,但这并不是真正需要的。
顺便说一句,您描述的数据结构可以通过使用哈希来改进。您可以将用户数据分组到一个散列对象中,而不是将用户数据存储在单独的键中。
使用排序命令
您可以使用 Redis 排序命令在一次往返中检索数据。
redis> set users:1:name "daniel"
OK
redis> set users:1:age 24
OK
redis> set users:2:name "user2"
OK
redis> set users:2:age 24
OK
redis> sadd events:1:attendees users:1 users:2
(integer) 2
redis> sort events:1:attendees by nosort get *:name get *:age
1) "user2"
2) "24"
3) "daniel"
4) "24"
使用流水线
Ruby 客户端支持流水线(即能够向 Redis 发送多个查询并等待多个回复)。
keys = $redis.smembers("events:1:attendees")
res = $redis.pipelined do
keys.each do |x|
$redis.mget(x+":name",x+":age")
end
end
上面的代码将仅在两次往返中检索数据。
使用可变参数命令
MGET 命令可用于一次检索多个数据:
redis> smembers events:1:attendees
1) "users:2"
2) "users:1"
redis> mget users:1:name users:1:age users:2:name users:2:age
1) "daniel"
2) "24"
3) "user2"
4) "24"
这里的费用也是两次往返。如果您可以保证要检索的密钥数量有限,则此方法有效。如果不是,流水线是一个更好的解决方案。