Redis基本数据类型(5)-----Zset

目录

1 简单介绍

2 常用命令

3. 数据结构


1 简单介绍

Redis有序集合zset与普通集合set非常相似,是一个没有重复元素的字符串集合。不同之处是有序集合的每个成员变量都关联了一个评分(score),这个评分被用来按照从最高分的方式排序集合中的成员。集合中的成员是唯一的,但是评分是可以重复的。

因为元素是有序的,所以可以很快的根据评分或者次序来获得一个范围内的元素

2 常用命令

zadd<key><score1><value1><score2><value2> 将一个或多个member元素以及score值加入到有序集合key值。

Redis基本数据类型(5)-----Zset

zrange<key> <start><stop> [withscores] 返回有序集合key中,下标在<start><stop>之间的元素,带withscores,可以让分数和值一起返回到结果集

Redis基本数据类型(5)-----Zset

 zrangebyscore key minmax [withscores] 返回有序集合key中,所有分数介于min和max之间有序集之间按照分数递增

Redis基本数据类型(5)-----Zset

 zrevrangebyscore key maxmin [withscores] 返回有序集合key中,所有分数按照从大到小排列

Redis基本数据类型(5)-----Zset

 zincrby <key> <increment> <value> 为元素score加上增量

 

Redis基本数据类型(5)-----Zset

zrem <key> <value> 删除该集合下,指定值的元素

Redis基本数据类型(5)-----Zset

zcount<key><min><max> 统计该集合下,分数区间内元素个数

Redis基本数据类型(5)-----Zset

zrank<key><value>返回该值在集合中的排名,从0开始

Redis基本数据类型(5)-----Zset

3. 数据结构

        SortedSet(zset)是Redis提供的一个非常特别的数据结构,一方面它等价于Java的数据结构Map<String,Double>,可以给每一个元素附一个权重score,另外一方面它又类似于TreeSet,内部的元素会按照权重score进行排序,可以得到每个元素的名词,还可以根据score来取元素的列表

        zset底层使用了两个数据结构

(1) hash的作用就是关联元素value和权重score,保障元素value的唯一性,可以通过元素value找到相应的score值

(2) 跳跃表,跳跃表的目的在于给元素value排序,根据score的范围获取元素列表

上一篇:通过结构体数组求最大值,最小值,平均数和及格率


下一篇:Golang并发编程入门教程