向爬虫而生---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构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

Redis指南及6.2.x版本安装过程

《Redis指南及6.2.x版本安装过程》Redis是完全开源免费的,遵守BSD协议,是一个高性能(NOSQL)的key-value数据库,Redis是一个开源的使用ANSIC语言编写、支持网络、... 目录概述Redis特点Redis应用场景缓存缓存分布式会话分布式锁社交网络最新列表Redis各版本介绍旧

Java如何从Redis中批量读取数据

《Java如何从Redis中批量读取数据》:本文主要介绍Java如何从Redis中批量读取数据的情况,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一.背景概述二.分析与实现三.发现问题与屡次改进3.1.QPS过高而且波动很大3.2.程序中断,抛异常3.3.内存消

Redis中的Lettuce使用详解

《Redis中的Lettuce使用详解》Lettuce是一个高级的、线程安全的Redis客户端,用于与Redis数据库交互,Lettuce是一个功能强大、使用方便的Redis客户端,适用于各种规模的J... 目录简介特点连接池连接池特点连接池管理连接池优势连接池配置参数监控常用监控工具通过JMX监控通过Pr

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

Redis迷你版微信抢红包实战

《Redis迷你版微信抢红包实战》本文主要介绍了Redis迷你版微信抢红包实战... 目录1 思路分析1.1hCckRX 流程1.2 注意点①拆红包:二倍均值算法②发红包:list③抢红包&记录:hset2 代码实现2.1 拆红包splitRedPacket2.2 发红包sendRedPacket2.3 抢

Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)

《Golang实现Redis分布式锁(Lua脚本+可重入+自动续期)》本文主要介绍了Golang分布式锁实现,采用Redis+Lua脚本确保原子性,持可重入和自动续期,用于防止超卖及重复下单,具有一定... 目录1 概念应用场景分布式锁必备特性2 思路分析宕机与过期防止误删keyLua保证原子性可重入锁自动

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red