sql >> Databasteknik >  >> NoSQL >> Redis

Är skillnaden mellan två listor igen?

Det finns inget inbyggt kommando för det - dina alternativ är antingen dra de två listorna och utför jämförelsen (för diff) i klienten, eller skriv ett Lua-skript som körs med EVAL kommando för att utföra det på serversidan. Här är ett exempel på ett sådant skript:

--[[ 
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)

Kör detta med redis-cli ser ut så här:

$ 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. Snabbare sätt att iterera alla nycklar och värden i redis db

  2. Fråga inbäddade objekt i Mongoid/rails 3 (Lägre än, Min-operatorer och sortering)

  3. MongoDB:Vad är anslutningspooling och timeout?

  4. Hur konfigurerar jag min MongoDB för att ta hänsyn till UTF-8?