时间:2021-05-23
go get github.com/garyburd/redigo/redis
n,err := c.Do("zadd","key","score","member") //写
result,err := redis.Values(c.Do("zrange","key",0,-1))//读
6.1:zadd
_, err1 := c.Do("zadd", "curbike", 1, "mobike", 2, "xiaolan", 3, "ofo", 4, "xiaoming")_, err2 := c.Do("zadd", "tmpdata", 0, "mobike", 0, "xiaolan", 0, "mysql", 0, "redis", 0, "mongo", 0, "xiaoming")if err1 != nil || err2 != nil { fmt.Println("zadd failed", err.Error())}6.2:zcard
num, err := c.Do("zcard", "curbike")if err != nil { fmt.Println("zcard failed", err.Error())} else { fmt.Printf("curbike's size is %s:", num)}6.3:zcount
num, err = c.Do("zcount", "curbike", 1, 3)if err != nil { fmt.Println("zcount failed ", err.Error())} else { fmt.Println("zcount num is :", num)}6.4:zincrby
num, err = c.Do("zincrby", "curbike", 3, "xiaolan")fmt.Println(reflect.TypeOf(num))if err != nil { fmt.Println("zincrby failed", err.Error())} else { fmt.Println("after zincrby the :", num)}6.5:zinterstore
_, err = c.Do("zinterstore", "internewset", 2, "curbike", "tmpdata")if err != nil { fmt.Println("zinterstore failed", err.Error())} else { result, err := redis.Values(c.Do("zrange", "internewset", 0, 10)) if err != nil { fmt.Println("interstore failed", err.Error()) } else { fmt.Printf("interstore newset elsements are:") for _, v := range result { fmt.Printf("%s ", v.([]byte)) } fmt.Println() }}6.6:zlexcount
num, err = c.Do("zlexcount", "tmpdata", "[mongo", "[xiaoming")if err != nil { fmt.Println("zlexcount failed", err.Error())} else { fmt.Println("zlexcount in tmpdata is :", num)}6.7:
res, err := redis.Values(c.Do("zrange", "curbike", 0, -1, "withscores"))if err != nil { fmt.Println("zrange in curbike failed", err.Error())} else { fmt.Printf("curbike's element are follow:") for _, v := range res { fmt.Printf("%s ", v.([]byte)) } fmt.Println()}6.8:zrangebylex
res, err = redis.Values(c.Do("zrangebylex", "tmpdata", "[mobike", "[redis"))if err != nil { fmt.Println("zrangebylex failed", err.Error())} else { fmt.Printf("zrangebylex in tmpdata:") for _, v := range res { fmt.Printf("%s ", v.([]byte)) } fmt.Println()}6.9:zrangebyscore
res, err = redis.Values(c.Do("zrangebyscore", "curbike", "(1", "(5"))if err != nil { fmt.Println("zrangebyscore failed", err.Error())} else { fmt.Printf("zrangebyscore's element:") for _, v := range res { fmt.Printf("%s ", v.([]byte)) } fmt.Println()}6.10:zrank
num, err = c.Do("zrank", "internewset", "xiaoming")if err != nil { fmt.Println("zrank failed ", err.Error())} else { fmt.Println("xiaoming's score is ", num)}6.11:
_, err = c.Do("zunionstore", "unewzset", 2, "curbike", "tmpdata")if err != nil { fmt.Println("zunionstore failed", err.Error())} else { res, err = redis.Values(c.Do("zrange", "unewzset", 0, 10)) if err != nil { fmt.Println("zunionstore failed", err.Error()) } else { fmt.Printf("union set are:") for _, v := range res { fmt.Printf("%s ", v.([]byte)) } fmt.Println() }}6.12:zscore
ret, err := c.Do("zscore", "internewset", "xiaolan")if err != nil { fmt.Println("zscore failed", err.Error())} else { fmt.Printf("curbike 's xiaolan score is:%s\n", ret)}6.13:zrevrank
num, err = c.Do("zrevrank", "curbike", "ofo")if err != nil { fmt.Println("zrevrank failed", err.Error())} else { fmt.Println("ofo's zrevrank is :", num)}6.14:zrevrangebyscore
res, err = redis.Values(c.Do("zrevrangebyscore", "unewzset", 10, 2))if err != nil { fmt.Println("zrevrangebyscore failed", err.Error())} else { fmt.Printf("zrevrangebyscore are:") for _, v := range res { fmt.Printf("%s ", v.([]byte)) } fmt.Println()}6.15:zrevrange
res, err = redis.Values(c.Do("zrevrange", "unewzset", 0, 10)) err != nil { fmt.Println("zrevrange failed:", err.Error())} else { fmt.Printf("zrevrange element:") for _, v := range res { fmt.Printf("%s ", v.([]byte)) } fmt.Println()}6.16:zrem
num, err = c.Do("zrem", "unewzset", "mysql")if err != nil { fmt.Println("zrem failed", err.Error())} else { fmt.Println("zrem result is:", num)}6.17:zremrangebyrank
num, err = c.Do("zremrangebyrank", "unewzset", 1, 4)if err != nil { fmt.Println("zremrangebyrank failed", err.Error())} else { fmt.Println("zremrangebyrank result:", num)}6.18:zremrangebyscore
num, err = c.Do("zremrangebyscore", "curbike", 2, 5)if err != nil { fmt.Println("zremrangebyscore failed", err.Error())} else { fmt.Println("zremrangebyscore result:", num)}完整代码路径
补充:go-redis使用之ZSet有序集合
ZSet(sorted set):有序不重复集合
ZSet的每个元素都会关联一个float64类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为2的32次方 - 1
func GetRedisClient() *redis.Client { return redis.NewClient(&redis.Options{ Addr: "localhost:6379", Password: "", DB: 0, })}// redisZsetTest Zset(sorted set有序不重复集合)func redisZsetTest(cli *redis.Client){ lang := []redis.Z{ redis.Z{Score: 90.0, Member: "java"}, redis.Z{Score: 80.0, Member: "go"}, redis.Z{Score: 70.0, Member: "python"}, redis.Z{Score: 60.0, Member: "php"}, redis.Z{Score: 50.0, Member: "ruby"}, } l1:= struct { Score float64 Member interface{} }{ 40, "javaScript", } //l2 :=redis.Z{ // Score: 30, // Member: "Object-C", //} // 添加一个值 cli.ZAdd("lang",l1) // 添加多个值 _,err:=cli.ZAdd("lang",lang...).Result() if err != nil { panic(err) } //升序:查询zset中指定区间的成员,-1代表取到最后 fmt.Println("ZRange:",cli.ZRange("lang",0,3).Val()) //[javaScript ruby php python] //降序:查询zset中指定区间的成员,-1代表取到最后 fmt.Println("ZRevRange:",cli.ZRevRange("lang",0,-1).Val()) // [java go python php ruby javaScript] // [Go javaScript ruby php python go java] opt:=redis.ZRangeBy{ Min: "50", //最小分数 Max: "90", //最大分数 Offset: 2, //在满足条件的范围,从offset下标处开始取值 Count: 3, //查询结果集个数 } //升序:根据opt条件查询Member成员 fmt.Println(cli.ZRangeByScore("lang",opt).Val()) // [python go java] //降序:根据opt条件查询Member成员 fmt.Println(cli.ZRevRangeByScore("lang",opt).Val()) //[python php ruby] //升序:根据下标范围返回的redis.Z结构体切片 fmt.Println(cli.ZRangeWithScores("lang",0,3).Val()) //[{40 javaScript} {50 ruby} {60 php} {70 python}] //降序:根据下标范围返回的redis.Z结构体切片 fmt.Println(cli.ZRevRangeWithScores("lang",0,-1).Val())//[{90 java} {80 go} {70 python} {60 php} {50 ruby} {40 javaScript}] //升序:根据opt条件,返回的redis.Z结构体切片 fmt.Println(cli.ZRangeByScoreWithScores("lang",opt).Val()) //降序:根据opt条件,返回的redis.Z结构体切片 fmt.Println(cli.ZRevRangeByScoreWithScores("lang",opt).Val()) fmt.Println(cli.ZRangeByLex("lang",opt).Val()) fmt.Println(cli.ZRevRangeByLex("lang",opt).Val()) // 获取指定成员的score f:=cli.ZScore("lang","go").Val() fmt.Println(f) // 80 // 获取指定成员的下标 fmt.Println(cli.ZRank("lang","python").Val()) //3 // 返回指定区间的成员个数 fmt.Println(cli.ZCount("lang","50","80").Val())//4 // 返回集合中成员的个数 fmt.Println(cli.ZCard("lang").Val()) //6 // 根据成员名称,移除指定成员(可以多个): 0:失败 0<:成功 fmt.Println(cli.ZRem("lang","c++").Val())//0 fmt.Println(cli.ZRem("lang","javaScript","java").Val())//2 fmt.Println(cli.ZRange("lang",0,-1).Val()) // [ruby php python go] // 升序:根据下标区间移除指定成员 fmt.Println(cli.ZRemRangeByRank("lang",1,2).Val()) //2:表示移除了两个 fmt.Println(cli.ZRangeWithScores("lang",0,-1).Val()) // [{50 ruby} {80 go}] // 升序:根据分数区间移除指定成员 fmt.Println(cli.ZRemRangeByScore("lang","70","90").Val()) //1:表示移除了一个 fmt.Println(cli.ZRangeWithScores("lang",0,-1).Val()) // [{50 ruby}]}func main() { rdb := GetRedisClient() defer rdb.Close() pong := rdb.Ping().Val() fmt.Printf("数据库连接状态:%v\n", pong) // 数据连接状态:PONG redisZsetTest(rdb)}以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Redis数据类型的详解概要:Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sortedse
详解redis数据结构之sds字符串在redis中使用非常广泛,在redis中,所有的数据都保存在字典(Map)中,而字典的键就是字符串类型,并且对于很大一部分
一、概述:Sorted-Sets和Sets类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中。它们之间的主要差别是Sorted-Sets中
一String类型首先使用启动服务器进程:redis-server.exe1.Set 设置Key对应的值为String类型的value。 例子:向Redis
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sortedset:有序集合)。Redis列表