Redis---集合

集合概述

  • Redis 存储数据的 Value 可以是一个 Set 集合,且集合中的每一个元素均 String 类型。Set与 List 非常相似,但不同之处是 Set 中的元素具有无序性与不可重复性,而 List 则具有有序性与可重复性。

  • 集合对象的编码可以是 intset 或者 hashtable。

  • 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。

命令

  1. sadd
  • 格式:sadd key member [member …]
  • 功能:将一个或多个 member 元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略。
  • 说明:假如 key 不存在,则创建一个只包含 member 元素作成员的集合。当 key 不是集合类型时,返回一个错误。

image-20230410164207324

  1. smembers
  • 格式:smembers key
  • 功能:返回集合 key 中的所有成员。
  • 说明:不存在的 key 被视为空集合。若 key 中包含大量元素,则该命令可能会阻塞 Redis服务。所以生产环境中一般不使用该命令,而使用 sscan 命令代替。

image-20230410164313762

  1. scard
  • 格式:scard key

  • 功能:返回 Set 集合的长度

  • 说明:当 key 不存在时,返回 0 。

image-20230410164414183

  1. sismember
  • 格式:sismember key member
  • 功能:判断 member 元素是否集合 key 的成员。
  • 说明:如果 member 元素是集合的成员,返回 1 。如果 member 元素不是集合的成员,或 key 不存在,返回 0 。

image-20230410164539417

  1. smove
  • 格式:smove source destination member
  • 功能:将 member 元素从 source 集合移动到 destination 集合。
  • 说明:如果 source 集合不存在或不包含指定的 member 元素,则 smove 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到destination 集合中去,返回 1。当 destination 集合已经包含 member 元素时, smove 命令只是简单地将 source 集合中的 member 元素删除。当source或destination 不是集合类型时,返回一个错误。

image-20230410170342016

  1. srem
  • 格式:srem key member [member …]
  • 功能:移除集合 key 中的一个或多个 member 元素,不存在的 member 元素会被忽略,且返回成功移除的元素个数。
  • 说明:当 key 不是集合类型,返回一个错误。

image-20230410170603215

  1. srandmember
  • 格式:srandmember key [count]
  • 功能:返回集合中的 count 个随机元素。count 默认值为 1。
  • 说明:若 count 为正数,且小于集合长度,那么返回一个包含 count 个元素的数组,数组中的元素各不相同。如果 count 大于等于集合长度,那么返回整个集合。如果count 为负数,那么返回一个包含 count 绝对值个元素的数组,但数组中的元素可能会出现重复。

image-20230410170806835

  1. spop
  • 格式:spop key [count]
  • 功能:移除并返回集合中的 count 个随机元素。count 必须为正数,且默认值为 1。
  • 说明:如果 count 大于等于集合长度,那么移除并返回整个集合。

image-20230410170926132

  1. sdiff 与 sdiffstore
  • 格式:sdiff key [key …] 或 sdiffstore destination key [key …]
  • 功能:返回第一个集合与其它集合之间的差集。差集,difference。
  • 说明:这两个命令的不同之处在于,sdiffstore 不仅能够显示差集,还能将差集存储到指定的集合 destination 中。如果 destination 集合已经存在,则将其覆盖。不存在的 key 被视为空集。

image-20230410171439957

  1. sinter 与 sinterstore
  • 格式:sinter key [key …] 或 sinterstore destination key [key …]
  • 功能:返回多个集合间的交集。交集,intersection。
  • 说明:这两个命令的不同之处在于,sinterstore 不仅能够显示交集,还能将交集存储到指定的集合 destination 中。如果 destination 集合已经存在,则将其覆盖。不存在的 key 被视为空集。

image-20230410171627550

  1. sunion 与 sunionstore
  • 格式:sunion key [key …] 或 sunionstore destination key [key …]
  • 功能:返回多个集合间的并集。并集,union。
  • 说明:这两个命令的不同之处在于,sunionstore 不仅能够显示并集,还能将并集存储到指定的集合 destination 中。如果 destination 集合已经存在,则将其覆盖。不存在的 key 被视为空集。

image-20230410171733645

应用场景

动态黑白名单

例如某服务器中要设置用于访问控制的黑名单。如果直接将黑名单写入服务器的配置文件,那么存在的问题是,无法动态修改黑名单。此时可以将黑名单直接写入 Redis,只要有客户端来访问服务器,服务器在获取到客户端 IP后先从 Redis的黑名单中查看是否存在该 IP,如果存在,则拒绝访问,否则访问通过。

有限随机数

有限随机数是指返回的随机数是基于某一集合范围内的随机数,例如抽奖、随机选人。通过 spop 或 srandmember 可以实现从指定集合中随机选出元素。

用户画像

社交平台、电商平台等各种需要用户注册登录的平台,会根据用户提供的资料与用户使用习惯,为每个用户进行画像,即为每个用户定义很多可以反映该用户特征的标签,这些标签就可以使用 sadd 添加到该用户对应的集合中。这些标签具有无序、不重复特征。同时平台还可以使用 sinter/sinterstore 根据用户画像间的交集进行好友推荐、商品推荐、客户推荐等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值
>