如何从 lua 脚本到节点 js return 带有字符串键值对的 table?
How to return a table with string keyed key value pairs from a lua script to node js?
我有一个 lua 脚本。我是 node.js 的 运行,我的脚本是 returning a lua table,其中包含键值对,例如 { '1': 15, '2 ':35}。在节点中,我得到一个空数组。但是,如果我 return 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.log("Error " + 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 );
TL;DR 你不能。
Redis 不支持键值类型的响应(尽管有人谈论在下一版本的协议 RESP3 中更改它)。
因此,从 Lua(带有 kv 对的 table)返回一个关联数组会导致一个空数组,正如您所发现的。您需要做的是将其展平,例如:
...
local reply = {} for k, v in pairs(a) do
table.insert(a, k)
table.insert(a, v)
end
return reply
或者简单地准备 a
在前面的循环中展开。最后,如果需要,您的客户必须了解这种格式并从中重组对象。
我有一个 lua 脚本。我是 node.js 的 运行,我的脚本是 returning a lua table,其中包含键值对,例如 { '1': 15, '2 ':35}。在节点中,我得到一个空数组。但是,如果我 return 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.log("Error " + 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 );
TL;DR 你不能。
Redis 不支持键值类型的响应(尽管有人谈论在下一版本的协议 RESP3 中更改它)。
因此,从 Lua(带有 kv 对的 table)返回一个关联数组会导致一个空数组,正如您所发现的。您需要做的是将其展平,例如:
...
local reply = {} for k, v in pairs(a) do
table.insert(a, k)
table.insert(a, v)
end
return reply
或者简单地准备 a
在前面的循环中展开。最后,如果需要,您的客户必须了解这种格式并从中重组对象。