Lua 中的 cjson 解码返回一个空数组的 Redis Cli

我有一个存储在 Redis 中的大型 JSON 对象数组,以编码字符串形式保存。

local string_foo = redis.call("get", "foo")

"[{\"id\":\"xxxxxxxx\",\"block-scope\":[],\"history\":[{\"type\":\"answer\",\"timestamp\":1516295540951,\"message\":{\"mid\":\"mid.$cAACRSqSkpgVnO4cWglhCkHOU0XJQ\",\"seq\":24216,\"text\":\"fdjl\"}},{\"messageType\":\"text\",\"type\":\"messa ..."

我想用 Lua 脚本迭代这个数组,将这些数据转换为更易于管理的形式。但是,当我尝试使用 cjson 解码创建一个 Lua 表时......

local json_foo = cjson.decode(string_foo)

[[],[],[],[],[]...]

我得到了一系列空数组或集合(redis-cli ldb 不确定是哪种情况)

1) (empty list or set)
2) (empty list or set)
3) (empty list or set)
4) (empty list or set)
5) (empty list or set)
....

这是为什么呢?这个字符串很大,但不是特别大。(~6 MB) 这个字符串是使用 JSON.stringify 编码的。

点赞
用户5384363
用户5384363

如果你的 JSON 是一个字符串/数字/布尔类型的数组,你可以直接返回 json_foo,Redis 可以为你解析数组。

但是,如果你的 JSON 是一个对象数组,那就太复杂了,Redis 无法解析。你需要在你的 Lua 脚本中解析它。比如,你想返回你的 JSON 数组中所有的 id:

local json_foo = cjson.decode(string_foo)
local ids = {}
for idx, ele in pairs(json_foo) do ids[idx] = ele["id"] end
return ids
2018-08-06 16:22:45