我就廢話不多說了,大家還是直接看代碼吧~
package main import ( "fmt" "github.com/garyburd/redigo/redis" ) func main() { // 連接redis數(shù)據(jù)庫,指定數(shù)據(jù)庫的IP和端口 conn, err := redis.Dial("tcp", "36.99.16.197:6379") if err != nil { fmt.Println("Connect to redis error", err) return } else { fmt.Println("Connect to redis ok.") } // 函數(shù)退出時(shí)關(guān)閉連接 defer conn.Close() // 執(zhí)行一個(gè)有序zset插入 _, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot1") if err != nil { fmt.Println("redis set failed:", err) } // 再執(zhí)行一個(gè)有序zset插入 _, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot2") if err != nil { fmt.Println("redis set failed:", err) } // 讀取指定zset user_map, err := redis.StringMap(conn.Do("ZRANGE", "mykey", 0, 10, "withscores")) if err != nil { fmt.Println("redis get failed:", err) } else { fmt.Printf("Get mykey: %v \n", user_map) } for user := range user_map { fmt.Printf("user name: %v %v\n", user, user_map[user]) } }
輸出:
Connect to redis ok. Get mykey: map[robot1:1 robot2:1] user name: robot1 1 user name: robot2 1
補(bǔ)充:Redis中zset的golang實(shí)現(xiàn)
初衷是在不用Redis的前提下實(shí)現(xiàn)排行榜
項(xiàng)目地址https://github.com/liyiheng/zset
go get -u github.com/liyiheng/zset
Removed RWLock in the SortedSet.
Just implement it yourself if you need.
s := zset.New() // add data s.Set(66, 1001, "test1") s.Set(77, 1002, "test2") s.Set(88, 1003, "test3") s.Set(100, 1004, "liyiheng") s.Set(99, 1005, "test4") s.Set(44, 1006, "test5") // update data s.Set(44, 1001, "test1") // get rank by id rank, score, extra := s.GetRank(1004, false) // get data by rank id, score, extra := s.GetDataByRank(0, true) // get data by id dat, ok := s.GetData(1001) // delete data by id s.Delete(1001)
go test -test.bench=".*" BenchmarkSortedSet_Add-4 1000000 4121 ns/op BenchmarkSortedSet_GetRank-4 500000 3592 ns/op BenchmarkSortedSet_GetDataByRank-4 2000000 667 ns/op PASS ok zset 11.365s
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
標(biāo)簽:電子產(chǎn)品 遼寧 西雙版納 安康 儋州 海南 青海 物業(yè)服務(wù)
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用go操作redis的有序集合(zset)》,本文關(guān)鍵詞 使用,操作,redis,的,有序,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。