У меня есть lua-скрипт. Я использую node.js, и мой скрипт возвращает таблицу lua с парами ключ-значение в ней, например {'1': 15, '2': 35}. В узле я получаю пустой массив. Однако если я верну arrayName ['1']. Это дает мне правильную ценность 15. Что я здесь делаю не так. Я использую клиент node_redis для узла для 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']; -- This returns proper value 35
-- return a; This returns empty array to node
файл узла - luaExec.js
let fs = require('fs');
let redis = require('redis');
let client = redis.createClient();
client.on("error", cb);
function cb(err) {
console.info("Error " + err);
}
client.eval(fs.readFileSync('groupBy.lua'), 0, (err, replies) => {
if (err) cb(err);
console.info(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 );
TL; DR вы не можете.
Redis не поддерживает тип ответа "ключ-значение" (хотя есть разговоры об изменении этого в следующей версии протокола RESP3).
Таким образом, возвращение ассоциативного массива из Lua (таблица с парами kv), как вы выяснили, приводит к пустому массиву. Что вам нужно сделать, так это сгладить его, например:
...
local reply = {} for k, v in pairs(a) do
table.insert(a, k)
table.insert(a, v)
end
return reply
Или просто подготовьте a
, сплющенный в предыдущем цикле. Наконец, ваш клиент должен будет знать об этом формате и при необходимости перекомпоновывать объект из него.