Redis script to return an average
我正在用Redis编写LUA脚本,以返回已存储的两个键(XXX_COUNT和XXX_TOTAL)的除法结果,如果不存在任何键,则返回0。该脚本的代码如下:
1 2 3 4 5 6 7 | local count = redis.call("GET", KEYS[1]..'_COUNT') local total = redis.call("GET", KEYS[1]..'_TOTAL') if not count or not total then return 0 else return tonumber(total)/tonumber(count) end |
问题在于,当脚本返回" tonumber(total)/ tonumber(count)"时,其值始终为0,已经检查了键,并且它们具有非零值,这些值作为字符串存储在Redis中。此脚本有什么问题?
预先感谢!
我找到了解决方案,我需要在返回结果之前将结果转换为字符串:
1 2 3 4 5 6 7 8 | local count = redis.call("GET", KEYS[1]..'_COUNT') local total = redis.call("GET", KEYS[1]..'_TOTAL') if not count or not total then return 0 else local avg = tonumber(total)/tonumber(count) return tostring(avg) end |
希望对您有所帮助!