lua脚本中按顺序获取redis键值列表

我在redis中有一个列表作为键值存储。它的键名是日期,就像这样。

key
===
20160429
20160430
20160501
20160502

现在我想获取最后两个键,因此我在我的lua脚本中执行以下操作。

local data = {};
local keyslist = redis.call('keys', 'stats:day:*');
local key, users, redisData;
-- keyslist = #keyslist.sort(#keyslist, function(a, b) return a[2] > b[2] end);
-- keyslist = #keyslist.sort(#keyslist, function(a,b) if a>b then return true; else return false; end end);
for iCtr = 1, #keyslist do

    key = string.gsub(keyslist[iCtr], 'stats:day:','');
    redisData = redis.call('hmget', keyslist[iCtr], 'image','video');
    table.insert(data, {date=key, imgctr=redisData[1], vidctr=redisData[2]});
    if iCtr == 2 then break end
end

但是这将返回前两个记录,我需要最后两个记录(例如以下键名)

20160501
20160502

如何获取按顺序排列的键名列表?

点赞
用户2858170
用户2858170

Lua表格排序的示例代码:

keylist = {1,2,5,8,3, 5}

-- 下面这行代码会使keylist按升序排列(默认)

table.sort(keylist)

-- 这行代码相当于上面一行:

table.sort(keylist, function (a,b) return a < b end)

table.sort的第二个参数是一个函数,它接受两个表格值并返回如果第一个值较小则为真。

想要按降序排列表格,只需调用

table.sort(keylist, function(a,b)return a > b end)

请注意,你只能使用这种方法来排序表格值,而不能排序表格键。但是,因为你在不同的上下文中使用键,所以这应该可以解决你的问题。

2016-05-02 10:23:54
用户3038364
用户3038364

如果我理解你的意思正确的话,你可能想要做以下操作:

local count = 0
for iCtr = #keyslist-1,#keyslist do
  count=count+1
  --进行你的操作
  if count == 2 then break end
  --或者
  if iCtr == #keyslist then break end
end

这将从keyslist 的倒数第二个项目开始计数。需要注意的是,我没有测试这段代码,但应该可以工作。

2016-05-03 02:03:44