从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。但这感觉不对,有没有办法让所有与会者的信息一目了然?

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

@event.attendees.each do |att|

att.name

end

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

谢谢 :)

回答:

在项目上循环并同步访问每个元素不是很有效。使用Redis 2.4,可以使用多种方法来完成所需的操作:

  • 通过使用sort命令
  • 通过使用流水线
  • 通过使用可变参数命令

使用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

上面的代码将仅在两次往返中检索数据。

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"

这里的费用也是两次往返。如果您可以保证要检索的键数受到限制,则此方法有效。如果不是这样,流水线是更好的解决方案。

以上是 从Redis获取多个键值 的全部内容, 来源链接: utcz.com/qa/430359.html

回到顶部