作者:毕涛涛,致力于Java学习的践行者。原创文章,转载请注明出处。
set(集合)
Redis的集合相当于Java语言里面的HashSet,它内部的键值对是无序的唯一的。它的内部实现相当于一个特殊的字典,字典中所有的value都是一个值NULL。
当集合中最后一个元素移除后,数据结构自动删除,内存被回收。set结构可以用来存储活动中奖的用户ID,因为有去重功能,可以保证同一个用户不会中奖两次。
zset(有序列表)
zset 可能是Redis提供的最为特色的数据结构,它也是在面试中面试官最爱问的数据结构。它类似于Java的SortedSet 和 HashMap 的结合体,一方面它是一个set,保证了内部value的唯一性,另一方面它可以给每个value赋予一个score,代表这个value的排序权重。它的内部实现用的是一种叫着[跳跃列表]的数据结构。
zset中最后一个value被移除后,数据结构自动删除,内存被回收。zset可以用来存粉丝列表,value值是粉丝的用户ID,score是关注时间。我们可以对粉丝列表按关注时间进行排序。
zset 还可以用来存储学生的成绩,value值是学生的ID,score是他的考试成绩。我们可以对成绩按分数进行排序就可以得到他的名次。
以下代码摘自网络:
> zadd books 9.0 "think in java"
> zadd books 8.9 "java concurrency"
> zadd books 8.6 "java cookbook"
> zrange books 0 -1 # 按 score 排序列出,参数区间为排名范围
1) "java cookbook"
2) "java concurrency"
3) "think in java"
> zrevrange books 0 -1 # 按 score 逆序列出,参数区间为排名范围
1) "think in java"
2) "java concurrency"
3) "java cookbook"
> zcard books # 相当于 count()
(integer) 3
> zscore books "java concurrency" # 获取指定 value 的 score
"8.9000000000000004" # 内部 score 使用 double 类型进行存储,所以存在小数点精度问题
> zrank books "java concurrency" # 排名
(integer) 1
> zrangebyscore books 0 8.91 # 根据分值区间遍历 zset
1) "java cookbook"
2) "java concurrency"
> zrangebyscore books -inf 8.91 withscores # 根据分值区间 (-∞, 8.91] 遍历 zset,同时返回分值。inf 代表 infinite,无穷大的意思。
1) "java cookbook"
2) "8.5999999999999996"
3) "java concurrency"
4) "8.9000000000000004"
> zrem books "java concurrency" # 删除 value
(integer) 1
> zrange books 0 -1
1) "java cookbook"
2) "think in java"
常用命令
set集合是string类型的无序集合,set是通过hashtable实现的,对集合我们可以取交集、并集、差集。
- :向名称为key的set中添加元素。
小结:set 集合不允许重复元素 smembers查看set集合的元素。- :删除set集合元素。
- :随机返回删除的key。
- :返回两个集合的不同元素(哪个集合在前面就以哪个集合为标准)
- :将返回的的不同元素存储到另外一个集合里
小结:这里是把set1 和 set2 的不同元素(以set1为准)存储到set3集合里。- :返回集合的交集
- :返回交集结构,存入set3中。
- :取并集
- :取得并集,存入set3中。
- :从一个set集合移动到另一个set集合里
小结:将set1中的元素移动到set2中(相当于剪切复制)- :查看集合里元素个数。
- :判断元素是否为集合中的元素
小结:返回1代表是集合中的元素,0代表不是- :随机返回一个元素
- :向有序集合中添加一个元素,该元素如果存在,则更新顺序
小结:在重复插入的时候,会根据顺序属性更新。- :删除名称为key的zset中的元素member
- :以指定值去自动递增或者减少,用法和之前的incrby类似
- :找到指定区间范围的数据进行返回。
- :删除1到1(只删除索引1)
- :删除指定序号
- :返回排序索引 从大到小排序(升序排序之后再找索引)
注意:一个是顺序号 一个是索引zrank返回的索引- :返回排序索引,从大到小排序(降序排序之后再找索引)
- :返回集合里所有元素的个数。
- :返回集合中score在给定区间中的数量。
网友评论