Redis基本数据类型-set(集合)

阳光穿透心脏的1/2处 2022-02-17 10:17 371阅读 0赞

文章目录

  • set(集合)
  • set里的方法
    • sadd
    • smembers
    • sismember
    • scard
    • spop
    • sunion
    • srandmenber
    • sinter
    • srem
    • smove
    • sdiffstore
    • sdiff
    • sscan
    • sinterstore
    • sunionstore

set(集合)

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个成员)。

set里的方法

sadd

Sadd 命令将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。
假如集合 key 不存在,则创建一个只包含添加的元素作成员的集合。
当集合 key 不是集合类型时,返回一个错误。
注意:在Redis2.4版本以前, SADD 只接受单个成员值。
SADD KEY_NAME VALUE1..VALUEN

  1. redis 127.0.0.1:6379> SADD myset "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset "foo"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset "hello"
  6. (integer) 0
  7. redis 127.0.0.1:6379> SMEMBERS myset
  8. 1) "hello"
  9. 2) "foo"

smembers

Smembers 命令返回集合中的所有的成员。 不存在的集合 key 被视为空集合。
SMEMBERS KEY

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "world"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SMEMBERS myset1
  6. 1) "World"
  7. 2) "Hello"

sismember

Sismember 命令判断成员元素是否是集合的成员。
SISMEMBER KEY VALUE

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SISMEMBER myset1 "hello"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SISMEMBER myset1 "world"
  6. (integer) 0

scard

Scard 命令返回集合中元素的数量。SCARD KEY_NAME

  1. redis 127.0.0.1:6379> SADD myset "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset "foo"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset "hello"
  6. (integer) 0
  7. redis 127.0.0.1:6379> SCARD myset
  8. (integer) 2

spop

Spop 命令用于移除并返回集合中的一个随机元素。
SPOP KEY

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "world"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SPOP myset1
  8. "bar"
  9. redis 127.0.0.1:6379> SMEMBERS myset1
  10. 1) "Hello"
  11. 2) "world"

sunion

Sunion 命令返回给定集合的并集。不存在的集合 key 被视为空集。
SUNION KEY KEY1..KEYN

  1. 127.0.0.1:6379> sadd set1 "java"
  2. (integer) 1
  3. 127.0.0.1:6379> sadd set1 "python"
  4. (integer) 1
  5. 127.0.0.1:6379> sadd set1 "js"
  6. (integer) 1
  7. 127.0.0.1:6379> sadd set2 "js"
  8. (integer) 1
  9. 127.0.0.1:6379> sadd set2 "jquery"
  10. (integer) 1
  11. 127.0.0.1:6379> sunion set1 set2
  12. 1) "jquery"
  13. 2) "java"
  14. 3) "python"
  15. 4) "js"

srandmenber

Srandmember 命令用于返回集合中的一个随机元素。SRANDMEMBER KEY [count]

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "world"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SRANDMEMBER myset1
  8. "bar"
  9. redis 127.0.0.1:6379> SRANDMEMBER myset1 2
  10. 1) "Hello"
  11. 2) "world"

sinter

Sinter 命令返回给定所有给定集合的交集。 不存在的集合 key 被视为空集。 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
SINTER KEY KEY1..KEYN

  1. redis 127.0.0.1:6379> SADD myset "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset "foo"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SADD myset2 "hello"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SADD myset2 "world"
  10. (integer) 1
  11. redis 127.0.0.1:6379> SINTER myset myset2
  12. 1) "hello"

srem

Srem 命令用于移除集合中的一个或多个成员元素,不存在的成员元素会被忽略。
当 key 不是集合类型,返回一个错误。
在 Redis 2.4 版本以前, SREM 只接受单个成员值。
SREM KEY MEMBER1..MEMBERN

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "world"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SREM myset1 "hello"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SREM myset1 "foo"
  10. (integer) 0
  11. redis 127.0.0.1:6379> SMEMBERS myset1
  12. 1) "bar"
  13. 2) "world"

smove

Smove 命令将指定成员 member 元素从 source 集合移动到 destination 集合。
SMOVE 是原子性操作。
如果 source 集合不存在或不包含指定的 member 元素,则 SMOVE 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到 destination 集合中去。
当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。
当 source 或 destination 不是集合类型时,返回一个错误。
SMOVE SOURCE DESTINATION MEMBER

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "world"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SADD myset2 "foo"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SMOVE myset1 myset2 "bar"
  10. (integer) 1
  11. redis 127.0.0.1:6379> SMEMBERS myset1
  12. 1) "World"
  13. 2) "Hello"
  14. redis 127.0.0.1:6379> SMEMBERS myset2
  15. 1) "foo"
  16. 2) "bar"

sdiffstore

Sdiffstore 命令将给定集合之间的差集存储在指定的集合中。如果指定的集合 key 已存在,则会被覆盖。
SDIFFSTORE DESTINATION_KEY KEY1..KEYN

  1. redis 127.0.0.1:6379> SADD myset "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset "foo"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SADD myset2 "hello"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SADD myset2 "world"
  10. (integer) 1
  11. redis 127.0.0.1:6379> SDIFFSTORE destset myset myset2
  12. (integer) 2
  13. redis 127.0.0.1:6379> SMEMBERS destset
  14. 1) "foo"
  15. 2) "bar"

sdiff

Sdiff 命令返回给定集合之间的差集。不存在的集合 key 将视为空集。
SDIFF FIRST_KEY OTHER_KEY1..OTHER_KEYN

  1. redis 127.0.0.1:6379> SADD myset "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset "foo"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SADD myset2 "hello"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SADD myset2 "world"
  10. (integer) 1
  11. redis 127.0.0.1:6379> SDIFF myset myset2
  12. 1) "foo"
  13. 2) "bar"

sscan

Sscan 命令用于迭代集合键中的元素。
SSCAN KEY [MATCH pattern] [COUNT count]

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "hi"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> sscan myset1 0 match h*
  8. 1) "0"
  9. 2) 1) "hello"
  10. 2) "h1"

sinterstore

Sinterstore 命令将给定集合之间的交集存储在指定的集合中。如果指定的集合已经存在,则将其覆盖。SINTERSTORE DESTINATION_KEY KEY KEY1..KEYN

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "foo"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SADD myset2 "hello"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SADD myset2 "world"
  10. (integer) 1
  11. redis 127.0.0.1:6379> SINTERSTORE myset myset1 myset2
  12. (integer) 1
  13. redis 127.0.0.1:6379> SMEMBERS myset
  14. 1) "hello"

sunionstore

Sunionstore 命令将给定集合的并集存储在指定的集合 destination 中。
SUNIONSTORE DESTINATION KEY KEY1..KEYN

  1. redis 127.0.0.1:6379> SADD myset1 "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> SADD myset1 "world"
  4. (integer) 1
  5. redis 127.0.0.1:6379> SADD myset1 "bar"
  6. (integer) 1
  7. redis 127.0.0.1:6379> SADD myset2 "hello"
  8. (integer) 1
  9. redis 127.0.0.1:6379> SADD myset2 "bar"
  10. (integer) 1
  11. redis 127.0.0.1:6379> SUNIONSTORE myset myset1 myset2
  12. (integer) 1
  13. redis 127.0.0.1:6379> SMEMBERS myset
  14. 1) "bar"
  15. 2) "world"
  16. 3) "hello"
  17. 4) "foo"

发表评论

表情:
评论列表 (有 0 条评论,371人围观)

还没有评论,来说两句吧...

相关阅读