Go語言操作redis數(shù)據(jù)庫的方法
先上命令速查網(wǎng)站,菜鳥yyds
https://www.runoob.com/redis/redis-strings.html
操作redis的包是go-redis/redis
官方文檔 https://redis.uptrace.dev/guide/
github https://github.com/go-redis/redis
創(chuàng)建項目
創(chuàng)建test文件夾
創(chuàng)建 Redis_test.go 文件
直接上代碼,代碼解釋全寫在注釋里
package test import ( "context" "encoding/json" "fmt" "github.com/go-redis/redis/v8" "testing" "time" ) var ctx = context.Background() var rdb *redis.Client func init() { rdb = redis.NewClient(&redis.Options{ // 端口需要改,這里是docker的端口 Addr: "localhost:49153", Password: "redispw", // no password set DB: 0, // use default DB PoolSize:15, MinIdleConns: 10, //在啟動階段創(chuàng)建指定數(shù)量的Idle連接,并長期維持idle狀態(tài)的連接數(shù)不少于指定數(shù)量;。 //超時 //DialTimeout: 5 * time.Second, //連接建立超時時間,默認(rèn)5秒。 //ReadTimeout: 3 * time.Second, //讀超時,默認(rèn)3秒, -1表示取消讀超時 //WriteTimeout: 3 * time.Second, //寫超時,默認(rèn)等于讀超時 //PoolTimeout: 4 * time.Second, //當(dāng)所有連接都處在繁忙狀態(tài)時,客戶端等待可用連接的最大等待時長,默認(rèn)為讀超時+1秒。 }) } // 基礎(chǔ)使用 func Test_Base(t *testing.T) { // 添加key //0表示沒有過期時間 rdb.Set(ctx, "testKey", "xxx", 0) // 獲取值 val, err := rdb.Get(ctx, "testKey").Result() if err != nil { fmt.Println("錯誤", err) } fmt.Println("值:", val) // 設(shè)置key過期時間 成功true rdb.Expire(ctx, "testKey", time.Second*60) // 存在返回1 rdb.Exists(ctx, "testKey") // key不存在時設(shè)置值 rdb.SetNX(ctx, "unkey", "val", 0) rdb.Set(ctx, "testKey2", "xxx", 0) // 刪除key 可刪除多個 rdb.Del(ctx, "testKey2", "testKey") } // 字符串 func Test_String(t *testing.T) { // 設(shè)置值 rdb.Set(ctx, "strKey", 100, 0) rdb.Set(ctx, "straey", 100, 0) // key自增1 rdb.Incr(ctx, "strKey") // 增加 66 rdb.IncrBy(ctx, "straey", 66) // -1 rdb.Decr(ctx, "straey") // -5 rdb.DecrBy(ctx, "straey", 5) // 過期時間 rdb.TTL(ctx, "strKey") // str*ey : *為任意字符串 // str[kKac]ey : 匹配[] 內(nèi)的單個字符 strkey,strKey,straey,strcey // str?ey : ? 任意單個字符 // 掃描key iter := rdb.Scan(ctx, 0, "str?ey", 0).Iterator() for iter.Next(ctx) { fmt.Println("keys", iter.Val(), ": val", rdb.Get(ctx, iter.Val()).Val()) } if err := iter.Err(); err != nil { panic(err) } } // 哈希 func Test_Hash(t *testing.T) { rdb.HMSet(ctx,"hkey1","name","shushan","age",99,"b",true) // 以結(jié)構(gòu)體存入 注意redis tag type User struct { Name string `json:"name,omitempty" redis:"name"` Age int `json:"age,omitempty" redis:"age"` B bool `json:"b,omitempty" redis:"b"` //... } user1 := User{ Name: "shushan2", Age: 55, B: true, } // 結(jié)構(gòu)體序列化反序列化map 你也可以用其他包進(jìn)行轉(zhuǎn)化為map,但是注意轉(zhuǎn)化后的鍵名大小寫問題 m := make(map[string]interface{}) buf,_ := json.Marshal(user1) _ = json.Unmarshal(buf,&m) // 存入 rdb.HSet(ctx, "user4", m) // 取出綁定到結(jié)構(gòu)體 map也行 var user User rdb.HGetAll(ctx,"user4").Scan(&user) fmt.Printf(" %#v \n ",user) // test.User{Name:"shushan2", Age:55, B:true} // 獲取key下的所有值 *匹配方式與string的所有原理一樣 iter := rdb.HScan(ctx,"user4",0,"*",0).Iterator() for iter.Next(ctx) { fmt.Println("keys", iter.Val()) } if err := iter.Err(); err != nil { panic(err) } } // 列表 func Test_List(t *testing.T) { // 添加 rdb.LPush(ctx,"listKey1",111,222,333,444) rdb.RPush(ctx,"listKey1",5555) // 不存在不添加 rdb.LPushX(ctx,"unlistKey",111) var intf []int // 根據(jù)索引獲取 綁定到數(shù)組 rdb.LRange(ctx,"listKey1",0,10).ScanSlice(&intf) fmt.Println(intf) var i int // 彈出 rdb.LPop(ctx,"listKey1").Scan(&i) fmt.Println(i) //.... } // 集合 func Test_Set(t *testing.T) { // 添加 rdb.SAdd(ctx,"setKey1","m1","onlyk1") rdb.SAdd(ctx,"setKey2","m2","xca") sl,_:= rdb.SDiff(ctx,"setKey1","setKey2").Result() fmt.Println(sl) // onlyk1,m1 //隨機(jī)移除 var val string rdb.SPop(ctx,"setKey1").Scan(&val) fmt.Println(val) // ..... } // 管道 func Test_Pipe(t *testing.T) { // 官方描述 // Redis 管道允許客戶端命令服務(wù)器通過執(zhí)行任務(wù)而通過執(zhí)行任務(wù)來提高您的性能。 // 在管道中,像命令命令一樣將編寫 + 使用命令來執(zhí)行任務(wù),并將其用于執(zhí)行任務(wù),執(zhí)行任務(wù)不是一個地執(zhí)行100個命令。 // 理解為命令就像石頭,一次運送一個石頭 // 使用管道等于 用車裝石頭 Exec 時就運送過去 pipe := rdb.Pipeline() incr := pipe.Set(ctx, "pip_test","bt",0) pipe.Expire(ctx, "pip_test", time.Hour) // 提交 cmds, err := pipe.Exec(ctx) if err != nil { fmt.Println(err) } for _, cmd := range cmds { fmt.Println(cmd.String()) } // 該值得Exec提交后有效 fmt.Println(incr.Val()) }
其他操作都可以查看go-redis的源碼或者直接打出rdb.命令,go-redis 的函數(shù)命名方式和redis的命令是差不多的
到此這篇關(guān)于Go語言操作redis數(shù)據(jù)庫的方法的文章就介紹到這了,更多相關(guān)go操作redis內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語言學(xué)習(xí)之golang-jwt/jwt的教程分享
jwt是?json?web?token的簡稱。go使用jwt目前,主流使用的jwt庫是golang-jwt/jwt。本文就來和大家講講golang-jwt/jwt的具體使用,需要的可以參考一下2023-01-01Go語言開發(fā)kube-scheduler整體架構(gòu)深度剖析
這篇文章主要為大家介紹了Go語言開發(fā)kube-scheduler整體架構(gòu)深度剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04Go如何優(yōu)雅的關(guān)閉goroutine協(xié)程
本文將介紹首先為什么需要主動關(guān)閉goroutine,并介紹如何在Go語言中關(guān)閉goroutine的常見套路,包括傳遞終止信號和協(xié)程內(nèi)部捕捉終止信號,之后,文章列舉了需要主動關(guān)閉協(xié)程運行的常見場景,希望通過本文的介紹,讀者能夠掌握如何在適當(dāng)?shù)臅r候關(guān)閉goroutine2023-05-05Golang打包go項目部署到linux服務(wù)器正確方法
這篇文章主要給大家介紹了關(guān)于Golang打包go項目部署到linux服務(wù)器的正確方法,Go?是一個開源的編程語言,它能讓構(gòu)造簡單、可靠且高效的軟件變得容易,具有簡潔、快速、安全,并行、有趣、開源,內(nèi)存管理、v數(shù)組安全、編譯迅速的特征,需要的朋友可以參考下2023-10-10GoLang的sync.WaitGroup與sync.Once簡單使用講解
sync.WaitGroup類型,它比通道更加適合實現(xiàn)這種一對多的goroutine協(xié)作流程。WaitGroup是開箱即用的,也是并發(fā)安全的。同時,與之前提到的同步工具一樣,它一旦被真正的使用就不能被復(fù)制了2023-01-01使用GO語言實現(xiàn)Mysql數(shù)據(jù)庫CURD的簡單示例
本文主要介紹了使用GO語言實現(xiàn)Mysql數(shù)據(jù)庫CURD的簡單示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08