问题
在 Redis 里执行 get 或 hget 不存在的 key 或 field 时返回值在终端显式的是 (nil),类似于下面这样
127.0.0.1:6379> get test_version (nil)
如果在 Lua 脚本中判断获取到的值是否为空值时,就会产生比较迷惑的问题,以为判断空值的话就用 nil 就可以了,然鹅事实却并不是这样的,如下所示:
127.0.0.1:6379> get test_version (nil) 127.0.0.1:6379> EVAL "local a = redis.call('get',KEYS[1]) print(a) if a == 'nil' then return 1 else return 0 end" 1 test_version test_version (integer) 0
我们来看下执行 Lua 脚本返回结果的数据类型是什么
127.0.0.1:6379> get test_version (nil) 127.0.0.1:6379> EVAL "local a = redis.call('get',KEYS[1]) return type(a)" 1 test_version test_version "boolean"
通过上面的脚本可以看到,当 Redis 返回的结果为 (nil) 时候,其真实的数据类型为 boolean,因此我们直接判断 nil 是有问题的。
Redis 官方文档
通过翻阅官方文档,找到下面所示的一段话,
Redis to Lua conversion table.
Lua to Redis conversion table.
解决方案
通过官方文档,我们知道判断 Lua 脚本返回空值使用,应该直接判断 true/false,修改判断脚本如下所示
127.0.0.1:6379> get test_version (nil) 127.0.0.1:6379> EVAL "local a = redis.call('get',KEYS[1]) if a == false then return 'empty' else return 'not empty' end" 1 test_version test_version "empty"
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对小牛知识库的支持。
本文向大家介绍Android 使用volley过程中遇到的问题解决办法,包括了Android 使用volley过程中遇到的问题解决办法的使用技巧和注意事项,需要的朋友参考一下 Android 使用volley过程中遇到的问题解决办法 本文主要介绍使用 volley 过程中遇到的问题,错误提示: com.android.volley.NoConnectionError: java.io.Interr
我有一个使用线程(实际上是Spark)和Redis(绝地)的Scala程序。我为我的Redis操作定义了一个,其中我为连接定义了一个。我需要每个线程打开一个到Redis的连接,并与之并行工作 连接对象: 当我用一根线的时候,效果很好。但当多个线程使用它时,我会出错。起初,我在每个线程中得到了,其中“4”是一个随机字符() 然后从我尝试设置和,因为我也看到了,有时是redis。客户。绝地武士。例外。
本文向大家介绍在使用过程中都遇到了些什么问题?相关面试题,主要包含被问及在使用过程中都遇到了些什么问题?时的应答技巧和注意事项,需要的朋友参考一下 Dubbo 的设计目的是为了满足高并发小数据量的 rpc 调用,在大数据量下的性能表现并不好,建议使用 rmi 或 http 协议。
本文向大家介绍Lua math.fmod使用时的小数问题,包括了Lua math.fmod使用时的小数问题的使用技巧和注意事项,需要的朋友参考一下
当我尝试运行SBT时,我得到以下消息:
null Redis事务是有限的,无法特定键,并且所有键在上都不被监视;我们仅限于给定客户端上的单个正在进行的事务。 我见过许多redis用户声称lua脚本是他们所需要的全部的线程。甚至redis官方文档也表示,他们可能会删除交易,转而支持lua脚本。然而,有些情况下这是不够的,比如最标准的情况:使用redis作为缓存。 假设我们想从Redis中的持久数据存储中缓存一些数据。下面是一个快速的过程: