大家好 我是寸铁👊
总结了一篇【Redis】golang操作Redis基础入门sparkles:
喜欢的小伙伴可以点点关注 💝
Redis(Remote Dictionary Server)是一个开源的内存数据库,它主要用于存储键值对,并提供多种数据结构的支持。Redis 的主要作用包括:
总的来说,Redis 是一个功能丰富的内存数据库,可以用于多种场景,包括缓存、会话存储、消息队列、计数器和排行榜、分布式锁等,为应用程序提供高性能、高可用的数据存储和处理能力。
那怎么使用go语言实现Redis的基本操作呢?下面寸铁带你手把手实现!
var rdb *redis.Client // 建立redis连接 func init() { rdb = redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", DB: 0, }) }
Addr: 指定 Redis 服务器的地址,包括主机和端口号。在这里是本地主机的默认 Redis 端口 6379。
Password: Redis 服务器的访问密码,如果 Redis 设置了密码,需要在此处填入密码。
DB: 指定连接的 Redis 数据库编号。Redis 支持多个数据库,默认使用的是第一个数据库编号为 0。
ctx := context.Background() err := rdb.Set(ctx, "rediskey", "redisvalue", 0).Err() if err != nil { panic(err) }
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“rediskey”,指定要设置的键名。
键值:“redisvalue”,指定要设置的键值。
过期时间:0,表示该键永不过期。
getres, err := rdb.Get(ctx, "rediskey").Result() if err != nil { panic(err) } fmt.Println("get执行的result", getres)
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“rediskey”,指定要获取值的键名。
dores, err := rdb.Do(ctx, "GET", "rediskey").Result() if err != nil { panic(err) } fmt.Println("do get 执行的result", dores.(string))
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
Redis 命令:“GET”,指定要执行的 Redis 命令是 GET。
命令参数:“rediskey”,指定 GET 命令的键名。
oldres, err := rdb.GetSet(ctx, "rediskey", "newvalue").Result() if err != nil { panic(err) } fmt.Println("GetSet执行的result", oldres) // redisvalue
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“rediskey”,指定要设置值的键名。
新值:“newvalue”,指定要设置的新值。
err = rdb.SetNX(ctx, "key3", "value3", 0).Err() if err != nil { panic(err) }
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“key3”,指定要设置值的键名。
值:“value3”,指定要设置的值。
超时时间:0,表示不设置超时时间。
result, err := rdb.MGet(ctx, "key1", "key2", "key3").Result() if err != nil { panic(err) } fmt.Println(result)
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要获取值的键名:“key1”, “key2”, “key3”,指定了要获取值的多个键名。
setKey := rdb.MSet(ctx, "key1", "value1", "key2", "value2", "key3", "value3") if err != nil { panic(err) } fmt.Println(setKey)
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要设置值的键值对:“key1”, “value1”, “key2”, “value2”, “key3”, “value3”,这里同时设置了多个键值对。
i, err := rdb.Incr(ctx, "inckey").Result() fmt.Println("Incr自增后的值:", i) //1
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要自增的键名:“inckey”,指定了要进行自增操作的键名。
i2, err := rdb.IncrBy(ctx, "inckey", 2).Result() fmt.Println("IncrBy自增后的值", i2) //3
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要自增的键名:“inckey”,指定了要进行自增操作的键名。
自增的整数值:这里是 2,表示要将键的值增加 2。
i3, err := rdb.IncrByFloat(ctx, "inckey", 2.2).Result() fmt.Println("IncrByFloat自增后的值", i3) //5.2
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要自增的键名:“inckey”,指定了要进行自增操作的键名。
自增的浮点数值:这里是 2.2,表示要将键的值增加 2.2。
rdb.Del(ctx, "key1")
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要删除的键名:“key1”,指定了要进行删除操作的键名。
err = rdb.Del(ctx, "key2", "key3").Err() if err != nil { panic(err) }
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要删除的多个键名:“key2”, “key3”,指定了要进行删除操作的键名列表。
rdb.Expire(ctx, "key", 10*time.Second)
上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
要设置过期时间的键名:“key”,指定了要设置过期时间的键名。
过期时间:这里是 10 秒,表示在当前时间的基础上,键 “key” 会在 10 秒后过期失效。
package main import ( "context" "fmt" "github.com/go-redis/redis/v8" "time" ) // 建立redis连接 func init() { rdb = redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", DB: 0, }) } func main() { ctx := context.Background() err := rdb.Set(ctx, "rediskey", "redisvalue", 0).Err() if err != nil { panic(err) } getres, err := rdb.Get(ctx, "rediskey").Result() if err != nil { panic(err) } fmt.Println("get执行的result", getres) //redisvalue //使用DO 原生的操作 dores, err := rdb.Do(ctx, "GET", "rediskey").Result() if err != nil { panic(err) } fmt.Println("do get 执行的result", dores.(string)) //redisvalue //即使设置新的值 取到的是旧的值 但是在redis中是设置了新的值 oldres, err := rdb.GetSet(ctx, "rediskey", "newvalue").Result() if err != nil { panic(err) } fmt.Println("GetSet执行的result", oldres) //redisvalue //存在则不设置该值 不存在则设置该值 err = rdb.SetNX(ctx, "key3", "value3", 0).Err() if err != nil { panic(err) } //批量取出键的值 result, err := rdb.MGet(ctx, "key1", "key2", "key3").Result() if err != nil { panic(err) } fmt.Println(result) //批量设置键的值 类似Map 对于同一个键的值 再设置会进行覆盖 setKey := rdb.MSet(ctx, "key1", "value1", "key2", "value2", "key3", "value3") if err != nil { panic(err) } fmt.Println(setKey) //自增1 i, err := rdb.Incr(ctx, "inckey").Result() fmt.Println("Incr自增后的值:", i) //1 //自增设定的整数 i2, err := rdb.IncrBy(ctx, "inckey", 2).Result() fmt.Println("IncrBy自增后的值", i2) //3 //自增设定的浮点数 i3, err := rdb.IncrByFloat(ctx, "inckey", 2.2).Result() fmt.Println("IncrByFloat自增后的值", i3) //5.2 //自减1 i4, err := rdb.Decr(ctx, "inckey").Result() fmt.Println("Incr自增后的值:", i4) //0 3-->2 //自减设定的整数 i5, err := rdb.DecrBy(ctx, "inckey", 2).Result() fmt.Println("IncrBy自增后的值", i5) //0 2-->0 //单个删除 rdb.Del(ctx, "key1") //批量删除 err = rdb.Del(ctx, "key2", "key3").Err() if err != nil { panic(err) } //设置过期时间 10秒钟后失效 //rdb.Set(ctx, "key", "value", 10*time.Second) rdb.Expire(ctx, "key", 10*time.Second) }
看到这里的小伙伴,恭喜你又掌握了一个技能👊
希望大家能取得胜利,坚持就是胜利💪
我是寸铁!我们下期再见💕
【保姆级教程】Windows11下go-zero的etcd安装与初步使用
【保姆级教程】Windows11安装go-zero代码生成工具goctl、protoc、go-zero
【Go-Zero】手把手带你在goland中创建api文件并设置高亮
【Go-Zero】Error: user.api 27:9 syntax error: expected ‘:‘ | ‘IDENT‘ | ‘INT‘, got ‘(‘ 报错解决方案及api路由注意事项
【Go-Zero】Error: only one service expected goctl一键转换生成rpc服务错误解决方案
【Go-Zero】【error】 failed to initialize database, got error Error 1045 (28000):报错解决方案
【Go-Zero】Error 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)报错解决方案
【Go-Zero】type mismatch for field “Auth.AccessSecret“, expect “string“, actual “number“报错解决方案
【Go-Zero】Error: user.api 30:2 syntax error: expected ‘)‘ | ‘KEY‘, got ‘IDENT‘报错解决方案
【Go-Zero】Windows启动rpc服务报错panic:context deadline exceeded解决方案
【Go面试向】defer与time.sleep初探
【Go面试向】defer与return的执行顺序初探
【Go面试向】Go程序的执行顺序
【Go面试向】rune和byte类型的认识与使用
【Go面试向】实现map稳定的有序遍历的方式