Redis(六) 数据类型set

作者:毕涛涛,致力于Java学习的践行者。原创文章,转载请注明出处。

set(集合)

Redis的集合相当于Java语言里面的HashSet,它内部的键值对是无序的唯一的。它的内部实现相当于一个特殊的字典,字典中所有的value都是一个值NULL。
当集合中最后一个元素移除后,数据结构自动删除,内存被回收。set结构可以用来存储活动中奖的用户ID,因为有去重功能,可以保证同一个用户不会中奖两次。

set.png

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在给定区间中的数量。

你可能感兴趣的:(Redis(六) 数据类型set)