golang. 批量獲取redis中的緩存值

使用redis的pipeline,批量獲取redis中的key值時,報錯,分析發現,批量獲取時,exec後,會返回兩種值:nil 及 redis.Nil,git

這種狀況下,使用常規的 if err!=nil 的判斷方法判斷錯誤,是會報錯的。github

測試代碼:redis

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

}

運行結果:tcp

能夠看到,若是批量獲取的key中,有不存在的key,返回的會是redis.Nil,不然返回的是nil。測試

相關文章
相關標籤/搜索