go中redis模糊查询到key并且批量删除它
我们在需要删除很多的redis key的时候,我们很有可能是无法知道所有的key的但是我们可以进行模糊查询后,进行逐个删除,(当然你得知道你所有的key都是你自己用的不能删除别人用的key)。这里批量删除也就需要用到反射来进行删除,直接贴代码:func (cf *Func) DelRedisCatchBatch(keys ...string) {for _, redisKey := range k
·
我们在需要删除很多的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进行删除。
如果大家有更好的方法,可以提出来讨论一下
更多推荐
已为社区贡献1条内容
所有评论(0)