golang. 批量获取redis中的缓存值 原

栏目: Go · 发布时间: 7年前

内容简介:使用redis的pipeline,批量获取redis中的key值时,报错,分析发现,批量获取时,exec后,会返回两种值:nil 及 redis.Nil,这种情况下,使用常规的 if err!=nil 的判断方法判断错误,是会报错的。

21天精品区块链课程免费学习,深入实战行家带路,助力开发者轻松玩转区块链! >>> golang. 批量获取 <a href='https://www.codercto.com/topics/18994.html'>redis</a> 中的缓存值 原

使用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()

}

运行结果:

golang. 批量获取redis中的缓存值 原

可以看到,如果批量获取的key中,有不存在的key,返回的会是redis.Nil,否则返回的是nil。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

程序员的数学思维修炼(趣味解读)

程序员的数学思维修炼(趣味解读)

周颖 / 清华大学出版社 / 2014-4-1 / 45.00元

本书是一本专门为程序员而写的数学书,介绍了程序设计中常用的数学知识。本书门槛不高,不需要读者精通很多高深的数学知识,只需要读者具备基本的四则运算、乘方等数学基础知识和日常生活中的基本逻辑判断能力即可。本书拒绝枯燥乏味的讲解,而是代之以轻松活泼的风格。书中列举了大量读者都很熟悉,而且非常有趣的数学实例,并结合程序设计的思维和算法加以剖析,可以训练读者的数学思维能力和程序设计能力,进而拓宽读者的视野,......一起来看看 《程序员的数学思维修炼(趣味解读)》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

html转js在线工具
html转js在线工具

html转js在线工具