Redis
 sql >> Baza danych >  >> NoSQL >> Redis

Redis różni się między dwiema listami?

Nie ma wbudowanej komendy do tego - twoje opcje to albo ściągnięcie dwóch list i wykonanie porównania (dla porównania) w kliencie, albo napisanie skryptu Lua, który jest uruchamiany z EVAL polecenie, aby wykonać to po stronie serwera. Oto przykład takiego skryptu:

--[[ 
LDIFF key [key ...]
Returns the elements in the first list key that are also present in all other
keys.
]]--

-- A utility function that converts an array to a table
local function a2t(a)
  local t = {}
  for i, v in ipairs(a) do
    t[v] = true
  end
  return t
end

-- A utility function that converts a table to an array
local function t2a(t)
  local a = {}
  for k, _ in pairs(t) do
    a[#a+1] = k
  end
  return a
end

-- main
local key = table.remove(KEYS,1)
local elems = a2t(redis.call('LRANGE', key, 0, -1))

-- iterate remaining keys
while #KEYS > 0 do
  key = table.remove(KEYS,1)
  local check = a2t(redis.call('LRANGE', key, 0, -1))
  -- check each element in the current key for existence in the first key
  for k, _ in pairs(elems) do
    if check[k] then
      elems[k] = nil
    end
  end
end

-- convert the table to an array and reply
return t2a(elems)

Uruchamianie tego z redis-cli wygląda tak:

$ redis-cli LPUSH key1 value1 value2 value3
(integer) 3
$ redis-cli LPUSH key2 value1 value3 value4
(integer) 3
$ redis-cli --eval ldiff.lua key1 key2
1) "value2"


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Jak ustawić/pobrać pandas.DataFrame do/z Redis?

  2. docker-compose:połączenie redis odrzucone między kontenerami

  3. Nodejs, nie czekam na zakończenie zapytania Redis przed kontynuowaniem wykonywania

  4. Prototyp obiektu Node.JS może być tylko Object lub null z Redis

  5. Różnica między StackExchange.Redis i ServiceStack.Redis