从Redis获取多个键值

时间:2012-04-14 16:44:39

标签: ruby-on-rails-3 redis

我正在玩Redis,我有几个问题。是否可以从一组键中获取值?

示例:

users:1:name "daniel"
users:1:age  "24"

users:2:name "user2"
users:2:age  "24"

events:1:attendees "users:1", "users:2"

当我redis.get events:1:attendees时,它会返回"users:1", "users:2"。我可以遍历此列表并获取用户:1,获取用户:2。但是这感觉不对,有没有办法让所有与会者的信息在1上获得?!

在rails中我会做这样的事情:

@event.attendees.each do |att|
  att.name
end

但是在redis中我不能,因为它返回键而不是存储在该键上的实际对象。

谢谢:)

2 个答案:

答案 0 :(得分:38)

对项目进行循环并同步访问每个元素效率不高。使用Redis 2.4,有多种方法可以满足您的需求:

  • 使用sort命令
  • 使用流水线
  • 使用variadic参数命令

使用Redis 2.6,您也可以使用Lua脚本,但这里并不需要这样做。

顺便说一句,您描述的数据结构可以通过使用哈希来改进。您可以将它们分组到散列对象中,而不是将用户数据存储在单独的密钥中。

使用排序命令

您可以使用Redis sort命令在一次往返中检索数据。

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

以上代码仅在两次往返中检索数据。

使用variadic参数命令

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"

这里的费用也是两次往返。如果您可以保证要检索的密钥数量有限,则此方法有效。如果没有,流水线操作是一个更好的解决方案。

答案 1 :(得分:5)

您可以使用Redis'EVAL命令向其发送一个运行循环“服务器端”的Lua script并将结果返回到块中。