Redis
 sql >> Database >  >> NoSQL >> Redis

Ottenere più valori chiave da Redis

Fare un ciclo sugli elementi e accedere in modo sincrono a ciascun elemento non è molto efficiente. Con Redis 2.4, ci sono vari modi per fare quello che vuoi:

  • utilizzando il comando di ordinamento
  • utilizzando la pipeline
  • utilizzando i comandi dei parametri variadici

Con Redis 2.6 puoi anche utilizzare lo scripting Lua, ma qui non è necessario.

A proposito, la struttura dei dati che hai descritto potrebbe essere migliorata utilizzando gli hash. Invece di archiviare i dati utente in chiavi separate, puoi raggrupparli in un oggetto hash.

Utilizzo del comando di ordinamento

Puoi utilizzare il comando Redis sort per recuperare i dati in un viaggio di andata e ritorno.

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"

Utilizzo della pipeline

Il client Ruby supporta il pipelining (ovvero la capacità di inviare diverse query a Redis e attendere diverse risposte).

keys = $redis.smembers("events:1:attendees")
res = $redis.pipelined do
   keys.each do |x|
      $redis.mget(x+":name",x+":age")
   end
end

Il codice sopra recupererà i dati solo in due roundtrip.

Utilizzo del comando parametro variadic

Il comando MGET può essere utilizzato per recuperare più dati in un colpo solo:

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"

Il costo qui è anche di due viaggi di andata e ritorno. Funziona se puoi garantire che il numero di chiavi da recuperare è limitato. In caso contrario, la pipeline è una soluzione molto migliore.