Redis 集合类型(Set)和命令 (数据类型 四)

集合类型是一个无序、不重复的数据集合,它可以用于存储唯一的值,并提供了对集合进行交集、并集、差集等操作。

常用集合类型命令:

添加操作:
sadd key member1 member2 ...:向集合中添加一个或多个成员。

复制代码
# 添加三个用户到users集合中
sadd users alice bob lindow

删除操作:
srem key member1 member2 ...:从集合中删除一个或多个成员。

复制代码
srem users bob

spop key [count]:随机移除并返回集合中的一个或多个成员。

复制代码
spop users

smove source destination member:将指定成员从一个集合移动到另一个集合。

复制代码
# 将爱丽丝从用户集合移动管理员集合
smove users admins alice

成员判断操作:
sismember key member:判断成员是否存在于集合中。

复制代码
sismember users alice

scard key:获取集合的元素数量。

复制代码
scard users

smembers key:返回集合中的所有成员。

复制代码
smembers users

集合操作:
sunion key1 key2 ...:返回多个集合的并集,即合并多个集合中的所有成员。

复制代码
# 返回用户集合和管理员集合并集
sunion users admins

sinter key1 key2 ...:返回多个集合的交集,即获取多个集合中共同存在的成员。

复制代码
# 用户集合和活跃用户集合交集
sinter users active_users

sdiff key1 key2 ...:返回多个集合的差集,即获取第一个集合中存在但其他集合中不存在的成员。

复制代码
# 用户集合和黑名单集合差集
sdiff users blacklist

sunionstore destination key1 key2 ...:计算多个集合的并集,并将结果存储到指定的目标集合中。

复制代码
sunionstore new_users users active_users

sinterstore destination key1 key2 ...:计算多个集合的交集,并将结果存储到指定的目标集合中。

复制代码
sinterstore common_users users active_users

sdiffstore destination key1 key2 ...:计算多个集合的差集,并将结果存储到指定的目标集合中。

复制代码
sdiffstore valid_users users blacklist

基本类型数据使用场景

1.标签:

将每个标签作为集合中的一个元素,而每个元素可以关联到对应的文章、商品或用户等对象。通过集合提供的交集、并集、差集等操作,可以方便地进行标签的聚合、搜索和过滤。

2、用户关注和粉丝:

使用两个集合来表示用户关注的人和关注该用户的人。通过集合操作,可以快速获取用户关注的人、共同关注的人、粉丝列表等信息。

3.兴趣爱好推荐:

集合可以用于实现用户兴趣爱好推荐系统。通过将用户的兴趣爱好作为集合的元素,可以通过集合操作找到共同兴趣的用户,从而进行兴趣推荐。

4.投票:

每个用户可以通过将自己的 ID 添加到集合中来进行投票,而集合的大小可以表示投票的数量。通过集合操作,可以实现投票的计数、查找投票者等功能。

5.事件订阅与发布:

集合可以作为事件订阅与发布系统的一部分。订阅者可以将自己的标识添加到集合中,而发布者可以向集合中的订阅者发送事件。通过集合操作,可以方便地管理订阅者列表和事件的分发。

上一篇:列表类型(List)和命令

下一篇:有序集合类型(zSet)

相关推荐
编程小Y12 分钟前
MySQL原理
数据库·mysql
小石头 1008639 分钟前
MySQL 视图:把复杂变简单的“虚拟化”艺术
数据库·mysql
安当加密1 小时前
PostgreSQL 透明数据加密(TDE)方案与应用场景详解
数据库·postgresql
怪我冷i1 小时前
dbeaver如何连接PostgreSQL数据库
数据库·ai编程·ai写作
QH_ShareHub1 小时前
如何使用 NHANES 数据库
数据库
wuhen_n1 小时前
系统架构设计师(三):数据库系统
数据库·系统架构
DB虚空行者2 小时前
MySQL误删/批量更新数据恢复实战:基于Flashback工具的完整方案
数据库·mysql
IvorySQL2 小时前
外键的本质竟然是触发器?深入解析 PostgreSQL 约束底层
数据库·postgresql·开源
九皇叔叔2 小时前
MySQL Next-Key Lock 锁表事故全拆解(从现象到根治)
数据库·mysql
短剑重铸之日2 小时前
7天读懂MySQL|Day 4:锁与并发控制
数据库·mysql·架构