如何从 lua 脚本返回一个包含字符串键的键值对表格到 node.js 中?

我有一个 lua 脚本。我从 node.js 运行它,并且我的脚本返回一个包含键值对的 lua 表格,例如 { '1': 15, '2': 35 }。在 node.js 中,我得到的是一个空数组。但是如果我返回 arrayName['1'],它会给我正确的值 15。我在这里做错了什么?我在使用 node_redis 客户端连接 node 和 redis。下面是不同的文件。

Lua 脚本 - groupBy.lua

local db = "";
local table = "students";
local groupBy = "class";
local aggregate = "marks";

local a = {};
local marksGroupedByClass = {};
for i = 1, 4 do
    local dataArr = redis.call("hgetall", db..table..":"..i);
    local dataObj = {};
    for i = 1, #dataArr, 2 do
        dataObj[dataArr[i]] = dataArr[i+1];
    end
    if a[dataObj["class"]] then
        a[dataObj["class"]] = a[dataObj["class"]] + dataObj["marks"]
    else
        a[dataObj["class"]] = dataObj["marks"]
    end
end

return a['2'];      -- 这将返回正确的值 35
-- return a;            这将返回空数组到 node

node 文件 - luaExec.js

let fs = require('fs');
let redis  = require('redis');
let client = redis.createClient();

client.on("error", cb);

function cb(err) {
    console.log("错误 " + err);
}

client.eval(fs.readFileSync('groupBy.lua'), 0, (err, replies) => {
    if(err) cb(err);
    console.log(replies);
})

client.quit();

我使用这个脚本保存我的数据 - saveStudentData.lua

redis.call("hmset","students:1", "name", "A", "class", 1, "marks", 5 );
redis.call("hmset","students:2", "name", "B", "class", 1, "marks", 10 );
redis.call("hmset","students:3", "name", "C", "class", 2, "marks", 15 );
redis.call("hmset","students:4", "name", "D", "class", 2, "marks", 20 );
点赞
用户3160475
用户3160475

TL;DR 你不能。

Redis不支持键值类型的响应(尽管有关于在下一个版本的协议RESP3中更改的讨论)。

因此,从Lua返回一个关联数组(含kv对的表)会导致数组为空,正如你所发现的。你需要做的是将其展平,例如:

...
local reply = {} for k, v in pairs(a) do
  table.insert(reply, k)
  table.insert(reply, v)
end

return reply

或者简单地在前面的循环中展平"a"。最后,你的客户端必须意识到这种格式,并且在需要时重新组合对象。

2018-05-01 14:00:00