[Redis][Set]详细讲解

目录


0.前言

  • 集合类型也是保存多个字符串类型的元素的,但和列表类型不同的是

    • 集合中元素之间是⽆序的
    • 集合中元素不允许重复
  • 一个集合中最多可以存储 2 32 − 1 2^{32} - 1 232−1个元素

  • Redis除了⽀持集合内的增删查改操作,同时还⽀持多个集合取交集、并集、差集,合理地使⽤好集合类型,能在实际开发中解决很多问题


1.常用命令

1.SADD

  • 功能 :将⼀个或者多个元素添加到set
    • 注意 :重复的元素⽆法添加到set
  • 语法SADD key member [member ...]
  • 返回值 :本次添加成功的元素个数
  • 时间复杂度 : O ( 1 ) O(1) O(1)

2.SMEMBERS

  • 功能 :获取一个set中的所有元素
    • 注意:元素间的顺序是无序的
  • 语法SMEMBERS key
  • 返回值:所有元素的列表
  • 时间复杂度 : O ( N ) O(N) O(N)

3.SISMEMBER

  • 功能 :判断一个元素在不在set
  • 语法SISMEMBER key member
  • 返回值 ::
    • 1 :表⽰元素在set
    • 0 :表⽰元素不在set中或者key不存在
  • 时间复杂度 : O ( 1 ) O(1) O(1)

4.SCARD

  • 功能 :获取一个set的基数(cardinality),即set中的元素个数
  • 语法SCARD key
  • 返回值set内的元素个数
  • 时间复杂度 : O ( 1 ) O(1) O(1)

5.SPOP

  • 功能 :从set中删除并返回⼀个或者多个元素
    • 注意 :由于set内的元素是⽆序的,所以取出哪个元素实际是未定义⾏为,即可以看作随机的
  • 语法SPOP key [count]
  • 返回值:取出的元素
  • 时间复杂度 : O ( N ) O(N) O(N),N是count

6.SMOVE

  • 功能 :将一个元素从源set取出并放入目标set
  • 语法SMOVE src dest member
  • 返回值:1表示移动成功,0表示失败
  • 时间复杂度 : O ( 1 ) O(1) O(1)

7.SREM

  • 功能 :将指定的元素从set中删除
  • 语法SREM key member [member ...]
  • 返回值:本次操作删除的元素个数
  • 时间复杂度 : O ( N ) O(N) O(N),N是要删除的元素个数

2.集合间操作

0.是什么?

  • set支持交集(inter)、并集(union)、差集(diff)

1.SINTER

  • 功能 :获取给定set的交集中的元素
  • 语法SINTER key [key ...]
  • 返回值:交集的元素
  • 时间复杂度 : O ( N ∗ M ) O(N*M) O(N∗M),N是最⼩的集合元素个数,M是最⼤的集合元素个数

2.SINTERSTORE

  • 功能 :获取给定set的交集中的元素并保存到目标set
  • 语法:`SINTERSTORE dest key [key ...]
  • 返回值:交集的元素个数
  • 时间复杂度 : O ( N ∗ M ) O(N*M) O(N∗M),N是最⼩的集合元素个数,M是最⼤的集合元素个数

3.SUNION

  • 功能 :获取给定set的并集中的元素
  • 语法SUNION key [key ...]
  • 返回值:并集的元素
  • 时间复杂度 : O ( N ) O(N) O(N),N给定的所有集合的总的元素个数

4.SUNIONSTORE

  • 功能 :获取给定set的并集中的元素并保存到⽬标set
  • 语法SUNIONSTORE dest key [key ...]
  • 返回值:并集的元素个数
  • 时间复杂度 : O ( N ) O(N) O(N),N给定的所有集合的总的元素个数

5.SDIFF

  • 功能 :获取给定set的差集中的元素
  • 语法SDIFF key [key ...]
  • 返回值:差集的元素
  • 时间复杂度 : O ( N ) O(N) O(N),N给定的所有集合的总的元素个数

6.SDIFFSTORE

  • 功能 :获取给定set的差集中的元素并保存到目标set
  • 语法SDIFFSTORE dest key [key ...]
  • 返回值:差集的元素个数
  • 时间复杂度 : O ( N ) O(N) O(N),N给定的所有集合的总的元素个数

3.内部编码

1.intset(整数集合)

  • 当集合中的元素都是整数并且元素的个数⼩于set-max-intset-entries配置(默认512个)时,Redis会选⽤intset来作为集合的内部实现,从⽽减少内存的使⽤

2.hashtable(哈希表)

  • 当集合类型⽆法满⾜intset的条件时,Redis会使⽤hashtable作为集合的内部实现

4.使用场景

  • 集合类型⽐较典型的使⽤场景是标签(tag)
    • 例如:⼀个电⼦商务⽹站会对不同标签的⽤⼾做不同的产品推荐
  • 示例
    • 给用户添加标签

      bash 复制代码
      sadd user:1:tags tag1 tag2 tag5
      sadd user:2:tags tag2 tag3 tag5
      ...
      sadd user:k:tags tag1 tag2 tag4
    • 给标签添加用户

      bash 复制代码
      sadd tag1:users user:1 user:3
      sadd tag2:users user:1 user:2 user:3
      ...
      sadd tagk:users user:1 user:4 user:9 user:28
    • 删除用户下的标签

      bash 复制代码
      srem user:1:tags tag1 tag5
      ...
    • 删除标签下的用户

      bash 复制代码
      srem tag1:users user:1
      srem tag5:users user:1
      ...
    • 计算⽤⼾的共同兴趣标签

      bash 复制代码
      sinter user:1:tags user:2:tags

相关推荐
倔强的石头_18 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
初次攀爬者4 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再5 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip