使用go怎么对redis的有序集合进行操作?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
成都创新互联公司是专业的沂南网站建设公司,沂南接单;提供做网站、网站制作,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行沂南网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!package main import ( "fmt" "github.com/garyburd/redigo/redis" ) func main() { // 连接redis数据库,指定数据库的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.") } // 函数退出时关闭连接 defer conn.Close() // 执行一个有序zset插入 _, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot1") if err != nil { fmt.Println("redis set failed:", err) } // 再执行一个有序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
补充:Redis中zset的golang实现
初衷是在不用Redis的前提下实现排行榜
项目地址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
关于使用go怎么对redis的有序集合进行操作问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。