内容简介:使用redis的pipeline,批量获取redis中的key值时,报错,分析发现,批量获取时,exec后,会返回两种值:nil 及 redis.Nil,这种情况下,使用常规的 if err!=nil 的判断方法判断错误,是会报错的。
21天精品区块链课程免费学习,深入实战行家带路,助力开发者轻松玩转区块链! >>>
使用redis的pipeline,批量获取redis中的key值时,报错,分析发现,批量获取时,exec后,会返回两种值:nil 及 redis.Nil,
这种情况下,使用常规的 if err!=nil 的判断方法判断错误,是会报错的。
测试代码:
package main
import (
"github.com/go-redis/redis"
"log"
"strconv"
)
func main() {
client := redis.NewClient(&redis.Options{
Addr: "localhost:6379",
Password: "", // no password set
DB: 0, // use default DB
Network: "tcp",
PoolSize: 50,
})
if _, err := client.Ping().Result(); err != nil {
panic(err)
}
pipe := client.Pipeline()
log.Println("所有的key都存在:")
for i := 0; i < 4; i++ {
key := "n:" + strconv.FormatInt(int64(i), 10)
pipe.Get(key)
}
result, err := pipe.Exec()
log.Println(result)
log.Println(err == nil)
log.Println(err == redis.Nil)
log.Println("有不存在的key:")
for i := 0; i < 5; i++ {
key := "n:" + strconv.FormatInt(int64(i), 10)
pipe.Get(key)
}
result, err = pipe.Exec()
log.Println(result)
log.Println(err == nil)
log.Println(err == redis.Nil)
defer client.Close()
}
运行结果:
可以看到,如果批量获取的key中,有不存在的key,返回的会是redis.Nil,否则返回的是nil。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Apache源代码全景分析第1卷
2009-5 / 88.00元
《Apache源代码全景分析第1卷:体系结构与核心模块》是“Apache源代码全景分析”的第1卷。书中详细介绍了Apache的基础体系结构和核心模块的实现机制,包括配置文件、模块化结构、多任务并发,以及网络连接和请求读取,其中多任务并发体系结构是《Apache源代码全景分析第1卷:体系结构与核心模块》分析的重点,讨论了Prefork、Worker及WinNT三种MPM。《Apache源代码全景分析......一起来看看 《Apache源代码全景分析第1卷》 这本书的介绍吧!