Java实现Redis的集合(set)命令操作

 更新时间:2020年07月16日 15:01:36   作者:double_lifly  
这篇文章主要介绍了Java实现Redis的集合(set)命令操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

配置文件请看上篇Java实现redis https://www.jb51.net/article/190922.htm

下面测试redis的集合set的类型,注释里面的代码是linux中redis命令

package com.huadian.set;

import com.huadian.redisUntil.JedisPoolUntil;
import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.ScanResult;

import java.util.HashSet;

public class Set {
  private Jedis jedis = null;
  @Before
  public void fun(){
    jedis = JedisPoolUntil.getJedis();
  };

  /**
   *Redis Sadd 命令将一个或多个成员元素加入到集合中,已经存在于集合的成员元素将被忽略。

   假如集合 key 不存在,则创建一个只包含添加的元素作成员的集合。

   当集合 key 不是集合类型时,返回一个错误。
   redis 127.0.0.1:6379> SADD KEY_NAME VALUE1..VALUEN
   */
  @Test
  public void sadd(){
    HashSet<String> set1 = new HashSet<>();
    Long sadd = jedis.sadd("set", "冷夢");
    System.out.println(sadd);
  }

  /**
   * Redis Scard 命令返回集合中元素的数量。
   * redis 127.0.0.1:6379> SCARD KEY_NAME
   */
  @Test
  public void scard(){
    Long set = jedis.scard("set");
    System.out.println(set);
  }

  /**
   *Redis Sdiff 命令返回给定集合之间的差集。不存在的集合 key 将视为空集。
   */
  @Test
  public void sdiff(){
    java.util.Set<String> sdiff = jedis.sdiff("set");
    System.out.println(sdiff);
  }

  /**
   *Redis Sdiffstore 命令将给定集合之间的差集存储在指定的集合中。如果指定的集合 key 已存在,则会被覆盖
   * redis 127.0.0.1:6379> SDIFFSTORE DESTINATION_KEY KEY1..KEYN
   */
  @Test
  public void sdiffstore(){
    Long sdiffstore = jedis.sdiffstore("set", "冷萌");
    System.out.println(sdiffstore);
  }

  /**
   * Redis Sinter 命令返回给定所有给定集合的交集。 不存在的集合 key 被视为空集。 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
   * redis 127.0.0.1:6379> SINTER KEY KEY1..KEYN
   */
  @Test
  public void sinter(){
    java.util.Set<String> sinter = jedis.sinter("set", "冷萌");
    System.out.println(sinter);
  }

  /**
   * Redis Sismember 命令判断成员元素是否是集合的成员。
   * redis 127.0.0.1:6379> SISMEMBER KEY VALUE
   */
  @Test
  public void sismember(){
    Boolean sismember = jedis.sismember("set", "冷萌");
    System.out.println(sismember);
  }

  /**
   * Redis Smove 命令将指定成员 member 元素从 source 集合移动到 destination 集合。

   SMOVE 是原子性操作。

   如果 source 集合不存在或不包含指定的 member 元素,则 SMOVE 命令不执行任何操作,仅返回 0 。否则, member 元素从 source 集合中被移除,并添加到 destination 集合中去。

   当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。

   当 source 或 destination 不是集合类型时,返回一个错误
   redis 127.0.0.1:6379> SMOVE SOURCE DESTINATION MEMBER
   */
  @Test
  public void smove(){
    Long smove = jedis.smove("set", "冷萌", "set1");
    System.out.println(smove);
  }

  /**
   * Redis Spop 命令用于移除并返回集合中的一个随机元素。
   * redis 127.0.0.1:6379> SPOP KEY
   */
  @Test
  public void spop(){
    String set = jedis.spop("set");
    System.out.println(set);
  }

  /**
   * Redis Srandmember 命令用于返回集合中的一个随机元素。
   * redis 127.0.0.1:6379> SRANDMEMBER KEY [count]
   */
  @Test
  public void srandmember(){
    String set = jedis.srandmember("set");
    System.out.println(set);
  }

  /**
   * Redis Srem 命令用于移除集合中的一个或多个成员元素,不存在的成员元素会被忽略。
   * 当 key 不是集合类型,返回一个错误。
   * redis 127.0.0.1:6379> SREM KEY MEMBER1..MEMBERN
   */
  @Test
  public void srem(){
    Long srem = jedis.srem("set", "memory");
    System.out.println(srem);
  }

  /**
   * Redis Sunion 命令返回给定集合的并集。不存在的集合 key 被视为空集。
   * redis 127.0.0.1:6379> SUNION KEY KEY1..KEYN
   */
  @Test
  public void sunion(){
    java.util.Set<String> set = jedis.sunion("set");
    System.out.println(set);
  }
  @Test
  public void sscan(){
    ScanResult<String> set = jedis.sscan("set", 1);
    System.out.println(set);
  }
}

补充知识:redis set集合的增删改查

如图所示:

以上这篇Java实现Redis的集合(set)命令操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • spring-boot-maven-plugin报红解决方案(亲测有效)

    spring-boot-maven-plugin报红解决方案(亲测有效)

    本文主要介绍了spring-boot-maven-plugin报红解决方案,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • javaBean的基础知识及常见乱码解决方法

    javaBean的基础知识及常见乱码解决方法

    这篇文章主要介绍了javaBean的基础知识及常见乱码解决方法的相关资料,需要的朋友可以参考下
    2017-03-03
  • hadoop 切片机制分析与应用

    hadoop 切片机制分析与应用

    切片这个词对于做过python开发的同学一定不陌生,但是与hadoop中的切片有所区别,hadoop中的切片是为了优化hadoop的job在处理过程中MapTask阶段的性能达到最优而言
    2022-02-02
  • SpringBoot3集成Zookeeper的代码详解

    SpringBoot3集成Zookeeper的代码详解

    ZooKeeper是一个集中的服务,用于维护配置信息、命名、提供分布式同步、提供组服务,分布式应用程序以某种形式使用所有这些类型的服务,本文将给大家介绍SpringBoot3集成Zookeeper的代码,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • Java锁之自旋锁详解

    Java锁之自旋锁详解

    这篇文章主要介绍了Java锁之自旋锁详解,本文是系列文章的第一篇,请持续关注脚本之家java栏目,需要的朋友可以参考下
    2014-09-09
  • JavaWeb仓库管理系统详解

    JavaWeb仓库管理系统详解

    这篇文章主要为大家详细介绍了JavaWeb仓库管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Java Spring 循环依赖解析

    Java Spring 循环依赖解析

    这篇文章主要介绍了Java Spring 循环依赖解析,Spring 现在其实是我们 Java 程序开发离不开的基础框架,个人觉得除了 JDK 我们用得最多的 Java 中间件就是 Spring ,今天我们一起来学习一下 Spring 的循环依赖。下面详细内容需要的小伙伴可以参考一下
    2022-02-02
  • Spring Boot中使用Server-Sent Events (SSE) 实现实时数据推送教程

    Spring Boot中使用Server-Sent Events (SSE) 实

    Server-Sent Events (SSE) 是HTML5引入的一种轻量级的服务器向浏览器客户端单向推送实时数据的技术,本文主要介绍了Spring Boot中使用Server-Sent Events (SSE) 实现实时数据推送教程,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • Nacos源码阅读方法

    Nacos源码阅读方法

    这篇文章将会带大家阅读Nacos源码以及教大家阅读源码的技巧,感兴趣的朋友跟随小编一起看看Nacos源码阅读方法
    2022-03-03
  • Java案例实现不重复的随机数

    Java案例实现不重复的随机数

    这篇文章主要介绍了Java案例实现不重复的随机数,通过创建Set集合对象,可以使用HashSet也可以使用TreeSet,区别在于TreeSet是排序后的,创建随机数对象,获取一个随机数去重等操作,需要的朋友可以参考一下
    2022-04-04

最新评论