一架梯子,一头程序猿,仰望星空!

golang redis 有序集合(sorted set)


Redis 有序集合(sorted set)和集合一样也是string类型元素的集合,且不允许重复的成员,不同的是每个元素都会关联一个double类型的分数,这个分数主要用于集合元素排序。

下面介绍golang redis 有序集合的用法

go redis有序集合常用函数:

  • ZAdd - 添加一个或者多个元素到集合,如果元素已经存在则更新分数
  • ZCard - 返回集合元素个数
  • ZCount - 统计某个分数范围内的元素个数
  • ZIncrBy - 增加元素的分数
  • ZRange,ZRevRange - 返回集合中某个索引范围的元素,根据分数从小到大排序
  • ZRangeByScore,ZRevRangeByScore - 根据分数范围返回集合元素,元素根据分数从小到大排序,支持分页。
  • ZRem - 删除集合元素
  • ZRemRangeByRank - 根据索引范围删除元素
  • ZRemRangeByScore - 根据分数范围删除元素
  • ZScore - 查询元素对应的分数
  • ZRank, ZRevRank - 查询元素的排名

1.ZAdd

添加一个或者多个元素到集合,如果元素已经存在则更新分数

// 添加一个集合元素到集合中, 这个元素的分数是2.5,元素名是tizi
err := client.ZAdd("key", redis.Z{2.5,"tizi"}).Err()
if err != nil {
	panic(err)
}

下面是redis.Z结构体说明:

type Z struct {
	Score  float64 // 分数
	Member interface{} // 元素名
}

2.ZCard

返回集合元素个数

size, err := client.ZCard("key").Result()
if err != nil {
	panic(err)
}
fmt.Println(size)

3.ZCount

统计某个分数范围内的元素个数

// 返回: 1<=分数<=5 的元素个数, 注意:"1", "5"两个参数是字符串
size, err := client.ZCount("key", "1","5").Result()
if err != nil {
	panic(err)
}
fmt.Println(size)

// 返回: 1<分数<=5 的元素个数
// 说明:默认第二,第三个参数是大于等于和小于等于的关系。
// 如果加上( 则表示大于或者小于,相当于去掉了等于关系。
size, err := client.ZCount("key", "(1","5").Result()

4.ZIncrBy

增加元素的分数

// 给元素5,加上2分
client.ZIncrBy("key", 2,"5")

5.ZRange,ZRevRange

返回集合中某个索引范围的元素,根据分数从小到大排序

// 返回从0到-1位置的集合元素, 元素按分数从小到大排序
// 0到-1代表则返回全部数据
vals, err := client.ZRange("key", 0,-1).Result()
if err != nil {
	panic(err)
}

for _, val := range vals {
	fmt.Println(val)
}

ZRevRange用法跟ZRange一样,区别是ZRevRange的结果是按分数从大到小排序。

6.ZRangeByScore

根据分数范围返回集合元素,元素根据分数从小到大排序,支持分页。

// 初始化查询条件, Offset和Count用于分页
op := redis.ZRangeBy{
	Min:"2", // 最小分数
	Max:"10", // 最大分数
	Offset:0, // 类似sql的limit, 表示开始偏移量
	Count:5, // 一次返回多少数据
}
	
vals, err := client.ZRangeByScore("key", op).Result()
if err != nil {
	panic(err)
}

for _, val := range vals {
	fmt.Println(val)
}

7.ZRevRangeByScore

用法类似ZRangeByScore,区别是元素根据分数从大到小排序。

8.ZRangeByScoreWithScores

用法跟ZRangeByScore一样,区别是除了返回集合元素,同时也返回元素对应的分数

// 初始化查询条件, Offset和Count用于分页
op := redis.ZRangeBy{
	Min:"2", // 最小分数
	Max:"10", // 最大分数
	Offset:0, // 类似sql的limit, 表示开始偏移量
	Count:5, // 一次返回多少数据
}

vals, err := client.ZRangeByScoreWithScores("key", op).Result()
if err != nil {
	panic(err)
}

for _, val := range vals {
	fmt.Println(val.Member) // 集合元素
	fmt.Println(val.Score) // 分数
}

8.ZRem

删除集合元素

// 删除集合中的元素tizi
client.ZRem("key", "tizi")

// 删除集合中的元素tizi和xiaoli
// 支持一次删除多个元素
client.ZRem("key", "tizi", "xiaoli")

9.ZRemRangeByRank

根据索引范围删除元素

// 集合元素按分数排序,从最低分到高分,删除第0个元素到第5个元素。
// 这里相当于删除最低分的几个元素
client.ZRemRangeByRank("key", 0, 5)

// 位置参数写成负数,代表从高分开始删除。
// 这个例子,删除最高分数的两个元素,-1代表最高分数的位置,-2第二高分,以此类推。
client.ZRemRangeByRank("key", -1, -2)

10.ZRemRangeByScore

根据分数范围删除元素

// 删除范围: 2<=分数<=5 的元素
client.ZRemRangeByScore("key", "2", "5")

// 删除范围: 2<=分数<5 的元素
client.ZRemRangeByScore("key", "2", "(5")

11.ZScore

查询元素对应的分数

// 查询集合元素tizi的分数
score, _ := client.ZScore("key", "tizi").Result()
fmt.Println(score)

12.ZRank

根据元素名,查询集合元素在集合中的排名,从0开始算,集合元素按分数从小到大排序

rk, _ := client.ZRank("key", "tizi").Result()
fmt.Println(rk)

ZRevRank的作用跟ZRank一样,区别是ZRevRank是按分数从大到小排序。