• Redis学习笔记(5)-Set


    package cn.com;
    
    import java.util.HashMap;
    import java.util.Map;
    import java.util.Set;
    
    import redis.clients.jedis.Jedis;
    
    /**
     * 集合的所有操作方法
     * 
     * */
    public class Redis_Set {
    	public static Jedis redis = new Jedis("localhost", 6379);// 连接redis
    	
    	public static void zadd(){
    		Map<String,Double> map=new HashMap<String,Double>();
    		redis.zadd("user",map);
    		 
    	}
    	
    	
    	/**
    	 * 将一个或多个  元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略。
    	 * */
    	public static void sadd(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","d","e","f");
    		Set<String> setList=redis.smembers("user");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 * SCARD key
    	 * 返回集合 key 的基数(集合中元素的数量)
    	 * */
    	public static void scard(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","d","e","f");
    		Long number=redis.scard("user");
    		System.out.println(number);
    	}
    	
    	
    	/**
    	 * SDIFF key [key ...] 求差集
    	 * 返回一个集合的全部成员,该集合是所有给定集合之间的差集。
    	 * 不存在的 key 被视为空集。
    	 * 相当月user减去user1 剩下的 user 元素
    	 * */
    	public static void sdiff(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","z");
    		redis.sadd("user1", "a","c","d","f");
    		
    		Set<String> setList=redis.sdiff("user","user1");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 * SDIFFSTORE destination key [key ...]求差集 将结果放入新的结合中
    	 * 这个命令的作用和 SDIFF 类似,但它将结果保存到 destination 集合,而不是简单地返回结果集。
    	 * 如果 destination 集合已经存在,则将其覆盖。
    	 * destination 可以是 key 本身。
    	 * N 是所有给定集合的成员数量之和.
    	 * 例如:以下例子是 取出 user中在user1 不包含的元素 也就是(zzz)在user1 中不存在
    	 * */
    	public static void sdiffstore(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		redis.sadd("user1", "a","b","c","d","e","f");
    	 
    		long size=redis.sdiffstore("newuser","user","user1");
    		System.out.println("size:"+size);
    		Set<String> setList=redis.smembers("newuser");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 *  SINTER key [key ...] 求交集
    	 * 返回一个集合的全部成员,该集合是所有给定集合的交集。
    	 * 不存在的 key 被视为空集。
    	 * 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
    	 * */
    	public static void sinter(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		redis.sadd("user1", "a","b","c","d","e","f");
    		Set<String> setList=redis.sinter("user","user1");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 *  SINTER key [key ...] 求交集 跟sinter区别在于是将差集的结果集放入新的数组中 如下的:newuser
    	 * 返回一个集合的全部成员,该集合是所有给定集合的交集。
    	 * 不存在的 key 被视为空集。
    	 * 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
    	 * */
    	public static void sinterstore(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		redis.sadd("user1", "a","b","c","d","e","f");
    		long size=redis.sinterstore("newuser","user","user1");
    		System.out.println("交集的大小:"+size);
    		
    		Set<String> setList=redis.smembers("newuser");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 * SUNION key [key ...]
    	 * 返回一个集合的全部成员,该集合是所有给定集合的并集。
    	 * 不存在的 key 被视为空集。
    	 * */
    	public static void sunion(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		redis.sadd("user1", "a","b","c","d","e","f");
    		Set<String> setList=redis.sunion("user","user1");
    	
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 * SUNION key [key ...]  将两个集合的并集放入新的结合中 newuser
    	 * 返回一个集合的全部成员,该集合是所有给定集合的并集。
    	 * 不存在的 key 被视为空集。
    	 * */
    	public static void sunionstore(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		redis.sadd("user1", "a","b","c","d","e","f");
    		long l=redis.sunionstore("newuser","user","user1");
    		Set<String> setList=redis.smembers("newuser");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	
    	/**
    	 * SISMEMBER key member
    	 *判断 member 元素是否集合 key 的成员。
    	 * */
    	public static void sismember(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		 
    		boolean b=redis.sismember("user", "a");
    		boolean b1=redis.sismember("user", "不存在哦");
    		System.out.println("返回一个 true 跟 false");
    		System.out.println(b);
    		System.out.println(b1);
    	}
    	
    	/**
    	 * 获取集合对象
    	 * */
    	public static void smembers(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","d","e","f");
    		Set<String> setList=redis.smembers("user");
    		for(String s:setList){
    			System.out.println(s);
    		}
    	}
    	
    	
    	/**
    	 * SMOVE source destination member
    	 * SMOVE 是原子性操作。
    	 * @param srckey 源集合key
    	 * @param dstkey 目标集合key
    	 * @param member 要移动的元素
    	 * 将源集合中的 元素member 移动到目标集合中
    	 * 返回值:
     	 * 如果 member 元素被成功移除,返回 1 。
         * 如果 member 元素不是 source 集合的成员,并且没有任何操作对 destination 集合执行,那么返回 0 。
    	 */
    	public static void smove(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "a","b","c","zzzz");
    		redis.sadd("user1",  "d","e","f");
    		redis.smove("user", "user1", "zzzz"); 
    		System.out.println("======user剩下的元素应该是 a,b,c======");
    		Set<String> setList=redis.smembers("user");
    		for(String s:setList){
    			System.out.println(s);
    		}
    		
    		System.out.println("======user 1的元素应该是 d,e,f,zzz======");
    		Set<String> setList1=redis.smembers("user1");
    		for(String s:setList1){
    			System.out.println(s);
    		}
    	}
    	
    	/**
    	 * SPOP key
    	 * 移除并返回集合中的一个随机元素。
    	 * 如果只想获取一个随机元素,但不想该元素从集合中被移除的话,可以使用 SRANDMEMBER 命令。
    	 * */
    	public static void spop(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "1","2","3","4","5","6","7");
    		String s=redis.spop("user");
    		System.out.println("随机弹出并移除的元素:"+s);
    		Set<String> setList=redis.smembers("user");
    		for(String str:setList){
    			System.out.println(str);
    		}
    	}
    	
    	
    	/**
    	 * 如果命令执行时,只提供了 key 参数,那么返回集合中的一个随机元素。
    	 * */
    	public static void srandmember(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "1","2","3","4","5","6","7");
    		String s=redis.srandmember("user");
    		System.out.println("随机弹出不删除的元素:"+s);
    		 
    		Set<String> setList=redis.smembers("user");
    		for(String str:setList){
    			System.out.println(str);
    		}
    	}
    	
    	/**
    	 * SREM key member [member ...]
    	 * 移除集合 key 中的一个或多个 member 元素,不存在的 member 元素会被忽略。
    	 * 当 key 不是集合类型,返回一个错误。
    	 * */
    	public static void srem(){
    		redis.flushDB();//清除数据
    		redis.sadd("user", "1","2","3","4","5","6","7");
    		redis.srem("user", "1","3","5");//删除1,3,5
    		Set<String> setList=redis.smembers("user");
    		for(String str:setList){
    			System.out.println(str);
    		}
    	}
    	
    	
    	public static void main(String [] args){
    		sunionstore();
    	}
    }
    

      

  • 相关阅读:
    ansible(十)roles
    playbook变量(九)for循环
    playbook变量(八)循环迭代
    playbook变量(七)template 基本使用 when
    playbook变量(六)template 基本使用
    playbook变量(五)
    Sqoop2常用命令介绍
    Sqoop2入门之导入关系型数据库数据到HDFS上
    Sqoop2环境搭建
    Spark On Yarn中spark.yarn.jar属性的使用
  • 原文地址:https://www.cnblogs.com/zuolun2017/p/5610515.html
Copyright © 2020-2023  润新知