redis运行lua脚本hmget返回值为空判断问题

本文介绍了在Redis中使用Lua脚本处理HMGET命令返回空值时的判断问题。通过示例代码展示了直接判断返回值为空不准确的情况,并提出通过判断返回值是否为`false`来正确识别空值。分享了解决此问题的经验,以助他人避免遇到相同困扰。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、redis中准备测试数据
hmset test abcd 123 ABCD 456
hgetall test


2、网上有人说用内置函数next()判断

redis-cli -c -p 8000 -n 8 --eval 1.lua test

redis-cli -c -p 8000 -n 8 --eval 1.lua test1

测试结果  返回的类型都为number,

local table_res=redis.call('hmget', KEYS[1], "abcd", "ABCD", "other")

return table_res  测试结果:



return next(table_res)  测试结果:



return type(next(table_res))  测试结果:



if next(table_res)==nil then
     return "table_res is null"
end
redis set中的key不存在时,返回table元素的值为空,table不为空。 所以if条件判断为假。


下面判断table元素中的值是否为空:
if table_res[1]==nil then
return "table first value is null"
end

说明直接判断不行

查看return type(table_res[1]) 类型


所以我们修改为

if table_res[1]==false then
        return "table first value is null"
else
        return "not null"
end



总结:第一次用redis里运行lua脚本,一路磕磕喷喷;网上查了很多资料都没有想过问题的解决方案,把它记录下来希望能给大家帮助,少碰坑。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值