Redis
 sql >> डेटाबेस >  >> NoSQL >> Redis

रेडिस दो सूचियों के बीच भिन्न है?

इसके लिए कोई अंतर्निहित कमांड नहीं है - आपके विकल्प या तो दो सूचियों को खींचते हैं और क्लाइंट में तुलना (अंतर के लिए) करते हैं, या एक Lua स्क्रिप्ट लिखते हैं जो EVAL के साथ चलती है। इसे सर्वर-साइड करने के लिए कमांड। ऐसी स्क्रिप्ट के लिए यहां एक उदाहरण दिया गया है:

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

इसे redis-cli के साथ चलाना ऐसा दिखता है:

$ 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. रेल पर्यावरण लोड किए बिना रूबी रेस्क्यू

  2. GenericJackson2JsonRedisSerializer वर्ग और विशेषता पर ध्यान न दें

  3. क्या एक्शन केबल 5 को रेडिस की आवश्यकता है?

  4. रेडिस सर्वर बंद करो। न तो शटडाउन और न ही काम बंद करो

  5. पायथन और रेडिस:प्रबंधक/कार्यकर्ता अनुप्रयोग सर्वोत्तम अभ्यास