我们在需要删除很多的redis key的时候,我们很有可能是无法知道所有的key的但是我们可以进行模糊查询后,进行逐个删除,(当然你得知道你所有的key都是你自己用的不能删除别人用的key)。这里批量删除也就需要用到反射来进行删除,直接贴代码:

func (cf *Func) DelRedisCatchBatch(keys ...string) {
	for _, redisKey := range keys {
		keysMatch, err := providers.Redis.Do("keys", redisKey+"*").Result()
		if err != nil {
			_ = providers.Logger.Errorf("查询批量删除的redisKey失败", err)
		}
		// 查看匹配到的 所有key是不是slice进行返回的
		if reflect.TypeOf(keysMatch).Kind() == reflect.Slice {
			val := reflect.ValueOf(keysMatch)
			if val.Len() == 0 {
				continue
			}
			// 一个个删除这些key
			for i :=0; i < val.Len(); i ++ {
				providers.Redis.Del(val.Index(i).Interface().(string))
				fmt.Printf("删除了rediskey::%s \n", val.Index(i).Interface().(string))
			}
		}
	}
	return
}

这里的key模糊查询也是可以多参数传入的,如果你需要key的两边都是模糊查询,你可以改一下为

"*"+redisKey+"*", 这样可以两边都模糊查询。

最后删除的时候由于需要是string类型 我们必须val.Index(i).Interface() 进行类型断言之后断言成string进行删除。

        如果大家有更好的方法,可以提出来讨论一下

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐