向爬虫而生---Redis 基石篇4 <拓展Set>

2024-01-03 09:44

本文主要是介绍向爬虫而生---Redis 基石篇4 <拓展Set>,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

延伸上一篇:https://blog.csdn.net/m0_56758840/article/details/135349796

挖一挖集合的一些骚操作~

正文:

基本操作:

集合是Redis中的一种数据类型,它具有以下几个基本概念和特性:无重复、无序和集合间的运算。下面是几个常用的集合命令,以及一些案例来说明:

  1. sadd key <value>:将一个或多个成员添加到集合中。

    127.0.0.1:6379> sadd myset 1 2 3
    (integer) 3
    127.0.0.1:6379> sadd myset 3 4
    (integer) 1
    

    在上述示例中,我们使用sadd命令将元素1、2、3添加到名为myset的集合中。首次添加时,返回值为3,表示成功添加了3个成员。然后,我们再次添加元素3和4,但由于集合不允许重复成员,所以返回值为1,表示只有元素4被成功添加到集合中。

  2. srem key <value>:从集合中移除一个或多个成员。

    127.0.0.1:6379> srem myset 2 3
    (integer) 2
    

    在上述示例中,我们使用srem命令从名为myset的集合中移除元素2和3。返回值为2,表示成功移除了2个成员。

  3. scard key:计算集合的大小(基数)。

    127.0.0.1:6379> scard myset
    (integer) 2
    

    在上述示例中,我们使用scard命令计算名为myset的集合的大小。返回值为2,表示集合中有2个成员。

  4. sismember key <value>:判断指定成员是否属于集合。

    127.0.0.1:6379> sismember myset 1
    (integer) 1
    127.0.0.1:6379> sismember myset 5
    (integer) 0
    

    在上述示例中,我们使用sismember命令判断元素1和5是否属于集合。返回值为1表示元素1属于集合,返回值为0表示元素5不属于集合。

  5. srandmember key <count>:从集合中随机获取一个或多个成员。

    127.0.0.1:6379> srandmember myset 2
    1) "1"
    2) "4"
    

    在上述示例中,我们使用srandmember命令从名为myset的集合中随机获取2个成员。返回的成员是随机选择的,每次执行可能得到不同的结果。

  6. spop key:从集合中随机弹出一个成员。

    127.0.0.1:6379> spop myset
    "4"
    

    在上述示例中,我们使用spop命令从名为myset的集合中随机弹出一个成员。弹出的成员是随机选择的,并从集合中移除。

  7. smembers key:获取集合中的所有成员。

    127.0.0.1:6379> smembers myset
    1) "1"
    

    在上述示例中,我们使用smembers命令获取名为myset的集合中的所有成员。(容易造成阻塞,慎用)

通过使用这些集合命令,我们可以对集合进行添加、删除、统计等操作,还可以判断成员是否属于集合,并从集合中随机获取成员或弹出成员。这些命令非常适用于需要对成员进行唯一性管理、随机选择或进行集合间的运算等场景。.


集合的关键用法:

集合的关键用法中,包括了三个关于集合间运算的命令:sdiff(差集)、sinter(交集)、sunion(并集)。

sdiff命令:

  • sdiff key1 [key2 ...],返回给定集合之间的差集。
  • 差集是指在第一个集合中存在,但在其他集合中不存在的成员。
# 创建两个集合
127.0.0.1:6379> sadd set1 1 2 3 4
(integer) 4
127.0.0.1:6379> sadd set2 3 4 5 6
(integer) 4# 计算集合的差集
127.0.0.1:6379> sdiff set1 set2
1) "1"
2) "2"

使用sadd命令创建了两个集合set1set2,分别包含了不同的成员。然后,通过使用sdiff命令计算set1set2之间的差集,即在set1中存在但在set2中不存在的成员,返回结果为12

sinter命令:

  • sinter key1 [key2 ...],返回给定集合之间的交集。
  • 交集是指在所有给定集合中都存在的成员。
# 创建两个集合
127.0.0.1:6379> sadd set1 1 2 3 4
(integer) 4
127.0.0.1:6379> sadd set2 3 4 5 6
(integer) 4# 计算集合的交集
127.0.0.1:6379> sinter set1 set2
1) "3"
2) "4"

使用sadd命令创建了两个集合set1set2,分别包含了不同的成员。然后,通过使用sinter命令计算set1set2之间的交集,即在set1set2中都存在的成员,返回结果为34

sunion命令:

  • sunion key1 [key2 ...],返回给定集合之间的并集。
  • 并集是指将所有给定集合中的成员合并起来,去除重复的成员。
# 创建两个集合
127.0.0.1:6379> sadd set1 1 2 3 4
(integer) 4
127.0.0.1:6379> sadd set2 3 4 5 6
(integer) 4# 计算集合的并集
127.0.0.1:6379> sunion set1 set2
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"

使用sadd命令创建了两个集合set1set2,分别包含了不同的成员。然后,通过使用sunion命令计算set1set2之间的并集,即将set1set2中所有的成员合并起来,去除重复的成员,返回结果为123456


应用层面:

在Redis的集合数据类型中,可以应用于许多不同的开发场景,例如:

1.标签系统:
集合可以作为标签的容器,用于对数据进行标记和分类。例如,可以将用户标记为"管理员"、"VIP"、"新用户"等,以便更轻松地进行用户分类和查询。 
  •         sadd: 添加标签到集合中。
  •         srem: 从集合中删除指定的标签。
  •         smembers: 获取集合中的所有标签。       
2.实时统计:
通过将数据元素存储在集合中,可以进行实时的统计和计数操作。例如,可以使用集合记录每天访问网站的独立IP,并通过计算集合的大小获取独立访客数。        
  •         sadd: 将数据元素添加到集合中,用于记录每个数据元素的出现。
  •         scard: 获取集合的大小,可用于统计独立数据元素的数量。
3.好友关系:
集合可以用于表示用户之间的好友关系。通过将好友的ID存储在集合中,可以轻松地进行好友列表、共同好友和好友推荐等操作。
  •         sadd: 将好友的ID添加到集合中。
  •         srem: 从集合中删除指定的好友ID。
  •         sismember: 检查指定的用户是否为好友。
  •         smembers: 获取当前用户的所有好友。
4.权限管理:
集合可以用于实现权限管理系统。例如,可以将用户的权限名称存储在一个集合中,然后使用sismember命令来检查用户是否具有特定权限。
  •                 sadd: 将权限名称添加到集合中。
  •                 srem: 从集合中删除指定的权限名称。
  •                 sismember: 检查用户是否具有指定的权限。
5.兴趣匹配:
通过将用户的兴趣爱好存储在集合中,可以通过交集运算来找到具有共同兴趣的用户或进行兴趣匹配。
  •         sadd: 将用户的兴趣爱好添加到集合中。
  •         sinter: 计算两个或多个集合的交集,找到具有共同兴趣的用户。
6.订阅者系统:
集合可以用于存储和管理订阅者信息。例如,将订阅集合中的用户与发布集合中的发布者进行匹配,以实现消息发布和订阅模式。
  •         sadd: 将订阅者的信息添加到集合中。
  •         srem: 从集合中删除指定的订阅者。
  •         smembers: 获取所有订阅者的信息。

以上仅是一些在开发中使用Redis集合的示例,实际上,Redis的集合数据类型非常灵活和多功能,适用于许多实际场景。通过适当地使用集合命令和数据结构,可以构建高效、灵活和可扩展的应用程序

这篇关于向爬虫而生---Redis 基石篇4 <拓展Set>的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/565291

相关文章

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

Nginx指令add_header和proxy_set_header的区别及说明

《Nginx指令add_header和proxy_set_header的区别及说明》:本文主要介绍Nginx指令add_header和proxy_set_header的区别及说明,具有很好的参考价... 目录Nginx指令add_header和proxy_set_header区别如何理解反向代理?proxy

redis+lua实现分布式限流的示例

《redis+lua实现分布式限流的示例》本文主要介绍了redis+lua实现分布式限流的示例,可以实现复杂的限流逻辑,如滑动窗口限流,并且避免了多步操作导致的并发问题,具有一定的参考价值,感兴趣的可... 目录为什么使用Redis+Lua实现分布式限流使用ZSET也可以实现限流,为什么选择lua的方式实现

Redis中管道操作pipeline的实现

《Redis中管道操作pipeline的实现》RedisPipeline是一种优化客户端与服务器通信的技术,通过批量发送和接收命令减少网络往返次数,提高命令执行效率,本文就来介绍一下Redis中管道操... 目录什么是pipeline场景一:我要向Redis新增大批量的数据分批处理事务( MULTI/EXE

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Redis中的常用的五种数据类型详解

《Redis中的常用的五种数据类型详解》:本文主要介绍Redis中的常用的五种数据类型详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Redis常用的五种数据类型一、字符串(String)简介常用命令应用场景二、哈希(Hash)简介常用命令应用场景三、列表(L

Redis解决缓存击穿问题的两种方法

《Redis解决缓存击穿问题的两种方法》缓存击穿问题也叫热点Key问题,就是⼀个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击,本文给大家介绍了Re... 目录引言解决办法互斥锁(强一致,性能差)逻辑过期(高可用,性能优)设计逻辑过期时间引言缓存击穿:给

Redis中如何实现商品秒杀

《Redis中如何实现商品秒杀》:本文主要介绍Redis中如何实现商品秒杀问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录技术栈功能实现步骤步骤一:准备商品库存数据步骤二:实现商品秒杀步骤三:优化Redis性能技术讲解Redis的List类型Redis的Set

Redis如何实现刷票过滤

《Redis如何实现刷票过滤》:本文主要介绍Redis如何实现刷票过滤问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言一、概述二、技术选型三、搭建开发环境四、使用Redis存储数据四、使用SpringBoot开发应用五、 实现同一IP每天刷票不得超过次数六