当前位置: 首页 > 面试题库 >

从Redis获取多个键值

邢献
2023-03-14
问题内容

我目前正在与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脚本,但这并不是真正需要的。

顺便说一句,您描述的数据结构可以通过使用哈希来改善。可以将用户数据分组在一个哈希对象中,而不是将用户数据存储在单独的键中。

使用sort命令

您可以使用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获取多个键的值? 这将有两个用户。 如何在一个查询中检索具有键“ David”和“ Linda”的用户? 问题答案: 无需在Redis中引入新命令的方法有多种。 例如,您可以使用感兴趣的名称填充临时集,然后计算该临时集与zset之间的交集: 使用流水线操作,只会产生一次往返,并且您可以在tmp中填充任意数量的输入参数。 使用Redis 2.6,您还可以将这些行

  • 问题内容: 我将数据存储在Redis中。我将它存储在GUID,createday和它的大小中。 因此,我定义以下内容: 我希望查看我的数据库中的所有文件。因此,我尝试以下操作: 但是res是。我该怎么做? 问题答案: 返回存储在key处的哈希的所有字段和值,您不能指定掩码: http //redis.io/commands/hgetall 您可以调用获取符合条件的所有键的列表,然后循环获取所有值。

  • 问题内容: 假设我在Redis中有这些对: 键始终是十进制数字。当提供一个数字时,我想在两个方向上获得最接近数字的两个键。 例如,如果我搜索的邻居,则结果集应具有: 这可能吗?我还是Redis的新手,感谢您的帮助。 问题答案: 是和不是同一时间。 为什么是? 唯一的redis数据类型-SORTED SET允许您获取基于十进制的值范围。因此,使用ZRANGEBYSCORE,您可以按分数范围获取值。

  • 我在更新和获取键/值时使用ServiceStack Redis的AcquireLock方法,如下所示: 我扩展了AcqurieLock方法,以接受锁密钥过期时的额外参数。所以我想知道我是否需要AcquireLock?我的类在每个操作中都使用AcquireLock,比如Get 但是这种方法并不是每次都有效。例如,如果锁中的操作抛出异常,那么密钥将保持锁定状态。对于这种情况,我已将DefaultLoc

  • 问题内容: 我在我的socket.io聊天应用程序的Redis存储中存储了用户名/ SocketID对。 当用户断开连接时,我需要从Redis存储中删除用户名/ socketID对。我已经看到了如何从键中获取值,但从未从值中获取键。可能吗?或无论哪种方式,我怎么能只从值中删除键/值对。这是我的代码 用于在连接上添加存储 对于断开连接,客户端将不知道何时断开连接,可能是由于Internet连接断开而

  • 问题内容: 我使用telnet输入这样的命令行命令 所有这三个返回相同的错误。 问题答案: 如果只有telnet(而不是’redis-cli’),则需要使用Redis二进制安全统一协议在键名中使用空格,例如: 有关Redis二进制安全协议的更多信息:http : //redis.io/topics/protocol