如何获得与redis中特定模式不匹配的键?

在Redis中,键user *将打印以user开头的所有键.

例如:

keys user*
1) "user2"
2) "user1"

现在,我想要打印所有不以用户开头的键.

我怎么能这样做?

重要提示:始终使用SCAN而不是(邪恶的)KEYS

Redis的模式匹配在某种程度上受到功能限制(参见 util.c 中stringmatchlen的实现),并没有提供您寻求ATM的功能.也就是说,考虑以下可能的路线:

>扩展stringmatchlen以符合您的要求,可能将其作为PR提交.

>考虑一下你要做的事情 – 除非你为它们编制索引,否则获取一个密钥子集总是效率低下,考虑跟踪所有非用户密钥的名称(即在Redis集中).

>如果你真的坚持扫描整个键空间并匹配负面模式,那么实现这一点的一种方法就是使用一点点Lua魔法.

请考虑以下数据集和脚本:

127.0.0.1:6379> dbsize
(integer) 0
127.0.0.1:6379> set user:1 1
OK
127.0.0.1:6379> set use:the:force luke
OK
127.0.0.1:6379> set non:user a
OK

Lua(将此保存为scanregex.lua):

local re = ARGV[1]
local nt = ARGV[2]

local cur = 0
local rep = {}
local tmp

if not re then
  re = ".*"
end

repeat
  tmp = redis.call("SCAN", cur, "MATCH", "*")
  cur = tonumber(tmp[1])
  if tmp[2] then
    for k, v in pairs(tmp[2]) do
      local fi = v:find(re) 
      if (fi and not nt) or (not fi and nt) then
        rep[#rep+1] = v
      end
    end
  end
until cur == 0
return rep

输出 – 第一次常规匹配,第二次补码:

foo@bar:~$redis-cli --eval scanregex.lua , "^user"
1) "user:1"
foo@bar:~$redis-cli --eval scanregex.lua , "^user" 1
1) "use:the:force"
2) "non:user"

翻译自:https://stackoverflow.com/questions/29942541/how-to-get-keys-which-does-not-match-a-particular-pattern-in-redis

我来评几句
登录后评论

已发表评论数()

相关站点

+订阅
热门文章