Redis实战--SpringBoot中对Redis数据类型set的基本操作示例

简介: Redis实战--SpringBoot中对Redis数据类型set的基本操作示例

该文章是接上一篇文章《Redis整合SpringBoot示例》的后续,操作用例代码比较多,这里展示核心代码所占篇幅很多,所以单独抽出来写

set类型在SpringBoot中的使用代码如下

package com.example.echo.redis;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.test.context.junit4.SpringRunner;

/**
 * @author XLecho
 * Date 2019/11/9 0009
 * Time 13:36
 */
@RunWith(SpringRunner.class)
@SpringBootTest
public class RedisTypeSetUseTest {
   

    @Autowired
    private RedisTemplate<String, String> redisTemplate;

    /**
     * 在set中添加a b c
     */
    @Test
    public void testSaddSet() {
   
        redisTemplate.opsForSet().add("mySet", "d", "e", "f");
        System.out.println(redisTemplate.opsForSet().members("mySet"));
    }

    /**
     * 获取set的长度
     */
    @Test
    public void testScardSet() {
   
        System.out.println(redisTemplate.opsForSet().size("mySet"));
    }

    /**
     * 随机获取set集合中的元素
     */
    @Test
    public void testSrandmemberSet() {
   
        System.out.println(redisTemplate.opsForSet().randomMember("mySet"));
        System.out.println(redisTemplate.opsForSet().members("mySet"));
    }

    /**
     * 随机弹出set集合中的元素,弹出的元素会在set集合中删除
     */
    @Test
    public void testSpopSet() {
   
        System.out.println(redisTemplate.opsForSet().pop("mySet"));
        System.out.println(redisTemplate.opsForSet().members("mySet"));
    }

    /**
     * 移除set集合中指定元素
     */
    @Test
    public void testSremSet() {
   
        redisTemplate.opsForSet().remove("mySet", "b");
        System.out.println(redisTemplate.opsForSet().members("mySet"));
    }

    /**
     * 查看元素c是否存在set集合中,存在返回true,不存在返回false
     */
    @Test
    public void testSismemberSet() {
   
        System.out.println(redisTemplate.opsForSet().isMember("mySet", "c"));
    }

    /**
     * 获取两个集合的差集
     */
    @Test
    public void testSdiffSet() {
   
        redisTemplate.opsForSet().add("mySet1","a", "b", "c", "d", "e");
        redisTemplate.opsForSet().add("mySet2", "c", "d", "e", "f", "g");
        System.out.println(redisTemplate.opsForSet().difference("mySet1", "mySet2"));
    }

    /**
     * 获取两个集合的交集
     */
    @Test
    public void testSinterSet() {
   
        redisTemplate.opsForSet().add("mySet1","a", "b", "c", "d", "e");
        redisTemplate.opsForSet().add("mySet2", "c", "d", "e", "f", "g");
        System.out.println(redisTemplate.opsForSet().intersect("mySet1", "mySet2"));
    }

    /**
     * 获取两个集合的并集
     */
    @Test
    public void testSunionSet() {
   
        redisTemplate.opsForSet().add("mySet1","a", "b", "c", "d", "e");
        redisTemplate.opsForSet().add("mySet2", "c", "d", "e", "f", "g");
        System.out.println(redisTemplate.opsForSet().union("mySet1", "mySet2"));
    }

}
目录
相关文章
|
7月前
|
监控 Java API
Spring Boot 3.2 结合 Spring Cloud 微服务架构实操指南 现代分布式应用系统构建实战教程
Spring Boot 3.2 + Spring Cloud 2023.0 微服务架构实践摘要 本文基于Spring Boot 3.2.5和Spring Cloud 2023.0.1最新稳定版本,演示现代微服务架构的构建过程。主要内容包括: 技术栈选择:采用Spring Cloud Netflix Eureka 4.1.0作为服务注册中心,Resilience4j 2.1.0替代Hystrix实现熔断机制,配合OpenFeign和Gateway等组件。 核心实操步骤: 搭建Eureka注册中心服务 构建商品
1103 3
|
5月前
|
NoSQL Java 网络安全
SpringBoot启动时连接Redis报错:ERR This instance has cluster support disabled - 如何解决?
通过以上步骤一般可以解决由于配置不匹配造成的连接错误。在调试问题时,一定要确保服务端和客户端的Redis配置保持同步一致。这能够确保SpringBoot应用顺利连接到正确配置的Redis服务,无论是单机模式还是集群模式。
481 5
|
5月前
|
监控 Cloud Native Java
Spring Boot 3.x 微服务架构实战指南
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Spring Boot 3.x与微服务架构,探索云原生、性能优化与高可用系统设计。以代码为笔,在二进制星河中谱写极客诗篇。关注我,共赴技术星辰大海!(238字)
Spring Boot 3.x 微服务架构实战指南
|
6月前
|
存储 NoSQL 前端开发
Redis专题-实战篇一-基于Session和Redis实现登录业务
本项目基于SpringBoot实现黑马点评系统,涵盖Session与Redis两种登录方案。通过验证码登录、用户信息存储、拦截器校验等流程,解决集群环境下Session不共享问题,采用Redis替代Session实现数据共享与自动续期,提升系统可扩展性与安全性。
386 3
Redis专题-实战篇一-基于Session和Redis实现登录业务
|
6月前
|
消息中间件 Ubuntu Java
SpringBoot整合MQTT实战:基于EMQX实现双向设备通信
本教程指导在Ubuntu上部署EMQX 5.9.0并集成Spring Boot实现MQTT双向通信,涵盖服务器搭建、客户端配置及生产实践,助您快速构建企业级物联网消息系统。
2243 1
|
6月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
286 1
Redis专题-实战篇二-商户查询缓存
|
6月前
|
NoSQL Java 调度
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
分布式锁是分布式系统中用于同步多节点访问共享资源的机制,防止并发操作带来的冲突。本文介绍了基于Spring Boot和Redis实现分布式锁的技术方案,涵盖锁的获取与释放、Redis配置、服务调度及多实例运行等内容,通过Docker Compose搭建环境,验证了锁的有效性与互斥特性。
511 0
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
|
9月前
|
缓存 监控 NoSQL
Redis 实操要点:Java 最新技术栈的实战解析
本文介绍了基于Spring Boot 3、Redis 7和Lettuce客户端的Redis高级应用实践。内容包括:1)现代Java项目集成Redis的配置方法;2)使用Redisson实现分布式可重入锁与公平锁;3)缓存模式解决方案,包括布隆过滤器防穿透和随机过期时间防雪崩;4)Redis数据结构的高级应用,如HyperLogLog统计UV和GeoHash处理地理位置。文章提供了详细的代码示例,涵盖Redis在分布式系统中的核心应用场景,特别适合需要处理高并发、分布式锁等问题的开发场景。
544 42
|
9月前
|
机器学习/深度学习 存储 NoSQL
基于 Flink + Redis 的实时特征工程实战:电商场景动态分桶计数实现
本文介绍了基于 Flink 与 Redis 构建的电商场景下实时特征工程解决方案,重点实现动态分桶计数等复杂特征计算。通过流处理引擎 Flink 实时加工用户行为数据,结合 Redis 高性能存储,满足推荐系统毫秒级特征更新需求。技术架构涵盖状态管理、窗口计算、Redis 数据模型设计及特征服务集成,有效提升模型预测效果与系统吞吐能力。
970 10
|
9月前
|
缓存 NoSQL 算法
高并发秒杀系统实战(Redis+Lua分布式锁防超卖与库存扣减优化)
秒杀系统面临瞬时高并发、资源竞争和数据一致性挑战。传统方案如数据库锁或应用层锁存在性能瓶颈或分布式问题,而基于Redis的分布式锁与Lua脚本原子操作成为高效解决方案。通过Redis的`SETNX`实现分布式锁,结合Lua脚本完成库存扣减,确保操作原子性并大幅提升性能(QPS从120提升至8,200)。此外,分段库存策略、多级限流及服务降级机制进一步优化系统稳定性。最佳实践包括分层防控、黄金扣减法则与容灾设计,强调根据业务特性灵活组合技术手段以应对高并发场景。
2424 7