当前位置:   article > 正文

redis—Set集合

redis—Set集合

目录

前言

1.常见命令

2.使用场景


前言

集合类型也是保存多个字符串类型的元素的,但和列表类型不同的是,集合中1)元素之间是无序的2)元素不允许重复,如图2-24所示。一个集合中最多可以存储22 - 1个元素。Redis 除了支持集合内的增删查改操作,同时还支持多个集合取交集、并集、差集,合理地使用好集合类型,能在实际开发中解决很多问题。
图2-24集合类型

1.常见命令

SADD
将一个或者多个元素添加到set中。注意,重复的元素无法添加到set中。
语法:

SADD key member [member ...]

命令有效版本: 1.0.0之后
时间复杂度: 0(1)
返回值:本次添加成功的元素个数。
示例:

  1. redis> SADD myset "Hello"
  2. (integer) 1
  3. redis> SADD myset "World"
  4. (integer) 1
  5. redis> SADD myset "World"
  6. (integer) 0
  7. redis> SMEMBERS myset
  8. 1) "Hello"
  9. 2) "World"

SMEMBERS
获取一个set中的所有元素,注意,元素间的顺序是无序的。
语法:

SMEMBERS key 

命令有效版本: 1.0.0之后
时间复杂度: O(N) 
返回值:所有元素的列表。
示例:

  1. redis> SADD myset "Hello"
  2. (integer) 1
  3. redis> SADD myset "World"
  4. (integer) 1
  5. redis> SMEMBERS myset
  6. 1) "Hello"
  7. 2) "World"

SISMEMBER
判断一个元素在不在set中。
语法:

SISMEMBER key member 
  1. redis> SADD myset "one"
  2. (integer) 1
  3. redis> SISMEMBER myset "one"
  4. (integer) 1
  5. redis> SISMEMBER myset "two"
  6. (integer) 0

SCARD
获取一个set的基数(cardinality) ,即set中的元素个数。
语法:

SCARD key 

命令有效版本: 1.0.0之后
时间复杂度: 0(1)
返回值: set 内的元素个数。
示例:

  1. redis> SADD myset "Hello"
  2. (integer) 1
  3. redis> SADD myset "World"
  4. (integer) 1
  5. redis> SCARD myset
  6. (integer) 2

SPOP
从set中删除并返回一个或者多个元素。注意,由于set内的元素是无序的,所以取出哪个元素实际是未定义行为,即可以看作随机的。
语法:

SPOP key [count] 

命令有效版本: 1.0.0 之后
时间复杂度: O(N), n是count
返回值:取出的元素。
示例:

  1. redis> SADD myset "one"
  2. (integer) 1
  3. redis> SADD myset "two"
  4. (integer) 1
  5. redis> SADD myset "three"
  6. (integer) 1
  7. redis> SPOP myset
  8. "one"
  9. redis> SMEMBERS myset
  10. 1) "three"
  11. 2) "two"
  12. redis> SADD myset "four"
  13. (integer) 1
  14. redis> SADD myset "five"
  15. (integer) 1
  16. redis> SPOP myset 3
  17. 1) "three"
  18. 2) "four"
  19. 3) "two"
  20. redis> SMEMBERS myset
  21. 1) "five"

SMOVE
将一个元素从源set取出并放入目标set中。
语法:

SMOVE source destination member 

命令有效版本: 1.0.0之后
时间复杂度: 0(1)
返回值: 1表示移动成功,0表示失败。
示例:

  1. redis> SADD myset "one"
  2. (integer) 1
  3. redis> SADD myset "two"
  4. (integer) 1
  5. redis> SADD myotherset "three"
  6. (integer) 1
  7. redis> SMOVE myset myotherset "two"
  8. (integer) 1
  9. redis> SMEMBERS myset
  10. 1) "one"
  11. redis> SMEMBERS myotherset
  12. 1) "three"
  13. 2) "two"

SREM 
将指定的元素从set中删除。
语法
:

SREM key member [member ...] 

命令有效版本: 1.0.0之后
时间复杂度: O(N), N是要删除的元素个数.
返回值:本次操作删除的元素个数。
示例:

  1. redis> SADD myset "one"
  2. (integer) 1
  3. redis> SADD myset "two"
  4. (integer) 1
  5. redis> SADD myset "three"
  6. (integer) 1
  7. redis> SREM myset "one"
  8. (integer) 1
  9. redis> SREM myset "four"
  10. (integer) 0
  11. redis> SMEMBERS myset
  12. 1) "three"
  13. 2) "two"

集合间操作
交集(inter) 、并集(union) 、差集(diff) 的概念如图2-25所示。.
图2-25集合求交集、并集、差集

SINTER
获取给定set的交集中的元素。
语法:

SINTER key [key ...] 

命令有效版本: 1.0.0之后
时间复杂度:0(N*M),N是最小的集合元素个数.M是最大的集合元素个数.
返回值:交集的元素。
示例:

  1. redis> SADD key1 "a"
  2. (integer) 1
  3. redis> SADD key1 "b"
  4. (integer) 1
  5. redis> SADD key1 "c"
  6. (integer) 1
  7. redis> SADD key2 "c"
  8. (integer) 1
  9. redis> SADD key2 "d"
  10. (integer) 1
  11. redis> SADD key2 "e"
  12. (integer) 1
  13. redis> SINTER key1 key2
  14. 1) "c"

SINTERSTORE
获取给定set的交集中的元素并保存到目标set中。
语法:

SINTERSTORE destination key [key ...] 

命令有效版本: 1.0.0之后
时间复杂度:O(N*M),N是最小的集合元素个数.M是最大的集合元素个数.
返回值:交集的元素个数。
示例:

  1. redis> SADD key1 "a"
  2. (integer) 1
  3. redis> SADD key1 "b"
  4. (integer) 1
  5. redis> SADD key1 "c"
  6. (integer) 1
  7. redis> SADD key2 "c"
  8. (integer) 1
  9. redis> SADD key2 "d"
  10. (integer) 1
  11. redis> SADD key2 "e"
  12. (integer) 1
  13. redis> SINTERSTORE key key1 key2
  14. (integer) 1
  15. redis> SMEMBERS key
  16. 1) "c"

SUNION
获取给定set的并集中的元素。
语法:

SUNION key [key ...] 

命令有效版本: 1.0.0之后
时间复杂度: O(N), N给定的所有集合的总的元素个数.
返回值:并集的元素。
示例:

  1. redis> SADD key1 "a"
  2. (integer) 1
  3. redis> SADD key1 "b"
  4. (integer) 1
  5. redis> SADD key1 "c"
  6. (integer) 1
  7. redis> SADD key2 "c"
  8. (integer) 1
  9. redis> SADD key2 "d"
  10. (integer) 1
  11. redis> SADD key2 "e"
  12. (integer) 1
  13. redis> SUNION key1 key2
  14. 1) "a"
  15. 2) "c"
  16. 3) "e"
  17. 4) "b"
  18. 5) "d"

SUNIONSTORE 
获取给定set的并集中的元素并保存到目标set中。
语法:

SUNIONSTORE destination key [key ...] 

命令有效版本: 1.0.0之后
时间复杂度: 0(N), N给定的所有集合的总的元素个数.
返回值:并集的元素个数。
示例:

  1. redis> SADD key1 "a"
  2. (integer) 1
  3. redis> SADD key1 "b"
  4. (integer) 1
  5. redis> SADD key1 "c"
  6. (integer) 1
  7. redis> SADD key2 "c"
  8. (integer) 1
  9. redis> SADD key2 "d"
  10. (integer) 1
  11. redis> SADD key2 "e"
  12. (integer) 1
  13. redis> SUNIONSTORE key key1 key2
  14. (integer) 5
  15. redis> SMEMBERS key
  16. 1) "a"
  17. 2) "c"
  18. 3) "e"
  19. 4) "b"
  20. 5) "d"

SDIFF
获取给定set的差集中的元素。
语法:

SDIFF key [key ...] 

命令有效版本: 1.0.0之后
时间复杂度: O(N), N给定的所有集合的总的元素个数.
返回值:差集的元素。
示例: 

  1. redis> SADD key1 "a"
  2. (integer) 1
  3. redis> SADD key1 "b"
  4. (integer) 1
  5. redis> SADD key1 "c"
  6. (integer) 1
  7. redis> SADD key2 "c"
  8. (integer) 1
  9. redis> SADD key2 "d"
  10. (integer) 1
  11. redis> SADD key2 "e"
  12. (integer) 1
  13. redis> SDIFF key1 key2
  14. 1) "a"
  15. 2) "b"

SDIFFSTORE
获取给定set的差集中的元素并保存到目标set中。
语法:

SDIFFSTORE destination key [key ...] 

命令有效版本: 1.0.0 之后
时间复杂度: O(N), N给定的所有集合的总的元素个数.
返回值:差集的元素个数。
示例:

  1. redis> SADD key1 "a"
  2. (integer) 1
  3. redis> SADD key1 "b"
  4. (integer) 1
  5. redis> SADD key1 "c"
  6. (integer) 1
  7. redis> SADD key2 "c"
  8. (integer) 1
  9. redis> SADD key2 "d"
  10. (integer) 1
  11. redis> SADD key2 "e"
  12. (integer) 1
  13. redis> SDIFFSTORE key key1 key2
  14. (integer) 2
  15. redis> SMEMBERS key
  16. 1) "a"
  17. 2) "b"

命令小结
表2-6总结了集合类型的常见命令,开发人员可以根据自身需求进行选择。
表2-6集合类型命令

内部编码
集合类型的内部编码有两种:
●intset (整数集合) :当集合中的元素都是整数并且元素的个数小于set-max- intset-entries配置
(默认512个)时,Redis 会选用intset来作为集合的内部实现,从而减少内存的使用。
●hashtable (哈希表) :当集合类型无法满足intset的条件时,Redis会使用hashtable作为集合
的内部实现。
1)当元素个数较少并且都为整数时,内部编码为intset:

  1. 127.0.0.1:6379> sadd setkey 1 2 3 4
  2. (integer) 4
  3. 127.0.0.1:6379> object encoding setkey
  4. "intset"

2)当元素个数超过512个,内部编码为hashtable:

  1. 127.0.0.1:6379> sadd setkey 1 2 3 4
  2. (integer) 513
  3. 127.0.0.1:6379> object encoding setkey
  4. "hashtable"

3)当存在元素不是整数时,内部编码为hashtable:

  1. 127.0.0.1:6379> sadd setkey a
  2. (integer) 1
  3. 127.0.0.1:6379> object encoding setkey
  4. "hashtable"

2.使用场景

集合类型比较典型的使用场景是标签(tag) 。例如A用户对娱乐、体育板块比较感兴趣,B用户对历史、新闻比较感兴趣,这些兴趣点可以被抽象为标签。有了这些数据就可以得到喜欢同一个标签的人,以及用户的共同喜好的标签,这些数据对于增强用户体验和用户黏度都非常有帮助。例如一个电子商务网站会对不同标签的用户做不同的产品推荐。
下面的演示通过集合类型来实现标签的若干功能。
1)给用户添加标签

  1. sadd user:1:tags tag1 tag2 tag5
  2. sadd user:2:tags tag2 tag3 tag5
  3. ...
  4. sadd user:k:tags tag1 tag2 tag4

2)给标签添加用户

  1. sadd tag1:users user:1 user:3
  2. sadd tag2:users user:1 user:2 user:3
  3. ...
  4. sadd tagk:users user:1 user:4 user:9 user:28

3)删除用户下的标签

  1. srem user:1:tags tag1 tag5
  2. ...

4)删除标签下的用户

  1. srem tag1:users user:1
  2. srem tag5:users user:1
  3. ...

5)计算用户的共同兴趣标签

sinter user:1:tags user:2:tags

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/42455
推荐阅读
相关标签
  

闽ICP备14008679号