/**
* Set(集合)
* SADD,SCARD,SDIFF,SDIFFSTORE,SINTER,SINTERSTORE,SISMEMBER,SMEMBERS,SMOVE,SPOP,SRANDMEMBER,SREM,SUNION,SUNIONSTORE,SSCAN
*/
public class SetTypeTest {
private Jedis jedis; private static final String KEY = "set"; private static final String VALUE = "layman"; @Before
public void setUp() {
this.jedis = new Jedis(new JedisShardInfo("192.168.133.188", 6379));
} /**
* SADD key member [member ...]
* 将一个或多个 member 元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略。
* 假如 key 不存在,则创建一个只包含 member 元素作成员的集合。
* 当 key 不是集合类型时,返回一个错误。
*/
@Test
public void SADD() {
jedis.sadd(KEY, VALUE + 2, VALUE + 0, VALUE + 1);
SMEMBERS();
} /**
* SCARD key
* 返回集合 key 的基数(集合中元素的数量)。
*/
@Test
public void SCARD() {
System.out.println(jedis.scard(KEY));
} /**
* SDIFF key [key ...]
* 返回一个集合的全部成员,该集合是所有给定集合之间的差集。
* 不存在的 key 被视为空集。
* <p/>
* SDIFFSTORE destination key [key ...]
* 这个命令的作用和 SDIFF 类似,但它将结果保存到 destination 集合,而不是简单地返回结果集。
* 如果 destination 集合已经存在,则将其覆盖。
* destination 可以是 key 本身。
*/
@Test
public void SDIFF() {
SMEMBERS();
jedis.sadd(KEY + 0, VALUE + 1, VALUE + 3);
System.out.println(jedis.smembers(KEY + 0));
System.out.println(jedis.sdiff(KEY, KEY + 0));//返回值为KEY-KEY0的值
} /**
* SINTER key [key ...]
* 返回一个集合的全部成员,该集合是所有给定集合的交集。
* 不存在的 key 被视为空集。
* 当给定集合当中有一个空集时,结果也为空集(根据集合运算定律)。
* <p/>
* SINTERSTORE destination key [key ...]
* 这个命令类似于 SINTER 命令,但它将结果保存到 destination 集合,而不是简单地返回结果集。
* 如果 destination 集合已经存在,则将其覆盖。
* destination 可以是 key 本身。
*/
@Test
public void SINTER() {
System.out.println(jedis.sinter(KEY, KEY + 0));
} /**
* SISMEMBER key member
* 判断 member 元素是否集合 key 的成员。
*/
@Test
public void SISMEMBER() {
System.out.println(jedis.sismember(KEY, VALUE + 0));
System.out.println(jedis.sismember(KEY, VALUE + 5));
} /**
* SMEMBERS key
* 返回集合 key 中的所有成员。
* 不存在的 key 被视为空集合。
*/
@Test
public void SMEMBERS() {
Set<String> smembers = jedis.smembers(KEY);
System.out.println(smembers);
} /**
* SMOVE source destination member
* 将 member 元素从 source 集合移动到 destination 集合。
* SMOVE 是原子性操作。
* 如果source集合不存在或不包含指定的member元素,则SMOVE命令不执行任何操作,仅返回0。否则,member元素从source集合中被移除,并添加到destination 集合中去。
* 当 destination 集合已经包含 member 元素时, SMOVE 命令只是简单地将 source 集合中的 member 元素删除。
* 当 source 或 destination 不是集合类型时,返回一个错误。
*/
@Test
public void SMOVE() {
System.out.println(jedis.smembers(KEY));
System.out.println(jedis.smembers(KEY + 0));
jedis.smove(KEY, KEY + 0, "layman0");
System.out.println(jedis.smembers(KEY));
System.out.println(jedis.smembers(KEY + 0));
} /**
* SPOP key
* 移除并返回集合中的一个随机元素。
* 如果只想获取一个随机元素,但不想该元素从集合中被移除的话,可以使用 SRANDMEMBER 命令。
*/
@Test
public void SPOP() {
SMEMBERS();
System.out.println(jedis.spop(KEY));
SMEMBERS();
} /**
* SRANDMEMBER key [count]
* 如果命令执行时,只提供了 key 参数,那么返回集合中的一个随机元素。
* 从 Redis 2.6 版本开始, SRANDMEMBER 命令接受可选的 count 参数:
* 如果 count 为正数,且小于集合基数,那么命令返回一个包含 count 个元素的数组,数组中的元素各不相同。如果 count 大于等于集合基数,那么返回整个集合。
* 如果 count 为负数,那么命令返回一个数组,数组中的元素可能会重复出现多次,而数组的长度为 count 的绝对值。
* 该操作和 SPOP 相似,但 SPOP 将随机元素从集合中移除并返回,而 SRANDMEMBER 则仅仅返回随机元素,而不对集合进行任何改动。
*/
@Test
public void SRANDMEMBER() {
System.out.println(jedis.smembers(KEY + 0));
System.out.println(jedis.srandmember(KEY + 0, 2));
System.out.println(jedis.srandmember(KEY + 0, -2));
} /**
* SREM key member [member ...]
* 移除集合 key 中的一个或多个 member 元素,不存在的 member 元素会被忽略。
* 当 key 不是集合类型,返回一个错误。
*/
@Test
public void SREM() {
SMEMBERS();
jedis.srem(KEY, "layman1");
SMEMBERS();
} /**
* SUNION key [key ...]
* 返回一个集合的全部成员,该集合是所有给定集合的并集。
* 不存在的 key 被视为空集。
* <p/>
* SUNIONSTORE destination key [key ...]
* 这个命令类似于 SUNION 命令,但它将结果保存到 destination 集合,而不是简单地返回结果集。
* 如果 destination 已经存在,则将其覆盖。
* destination 可以是 key 本身。
*/
@Test
public void SUNION() {
SMEMBERS();
jedis.sadd(KEY + 0, "layman" + new Random().nextInt(50));
System.out.println(jedis.sunion(KEY, KEY + 0));
}
}

Jedis操作Redis--Set类型的更多相关文章

  1. Jedis操作Redis技巧详解

    对于Redis的部署模式有两种,单机模式 和 集群模式.因此,本文的介绍也从这两个方面进行介绍.众所周知,Jedis是最著名的Redis java客户端操作类库,几乎支持所有的Redis操作.本文就是 ...

  2. Java中Jedis操作Redis与Spring的整合

    Redis是一个key-value存储系统.它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集合).这些数据类型都支持push/pop. ...

  3. Redis入门和Java利用jedis操作redis

    Redis入门和Java利用jedis操作redis Redis介绍 Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库. Redis 与其他 key - val ...

  4. Jedis操作Redis数据库

    添加Maven依赖: <dependencies> <!-- 单元测试 --> <dependency> <groupId>junit</grou ...

  5. Jedis操作Redis

    Jedis操作Redis的常用封装方法 @Resource(name="jedispool") private JedisPool pool=null; /** * 设置缓存对象过 ...

  6. 四、Jedis操作Redis

    前言:  原来我们操作mysql需要用的jdbc,现在操作redis则需要jedis,jedis是客户端,而redis是服务器,使用jedis客户端来操作redis. 在这里要使用jedis操作red ...

  7. JAVA中通过Jedis操作Redis连接与插入简单库

    一.简述 JAVA中通过Jedis操作Redis连接与插入简单库 二.依赖 <!-- https://mvnrepository.com/artifact/redis.clients/jedis ...

  8. jedis操作redis的几种常见方式总结

    Redis是一个著名的key-value存储系统,也是nosql中的最常见的一种,这篇文章主要给大家总结了关于在java中jedis操作redis的几种常见方式,文中给出了详细的示例代码供大家参考学习 ...

  9. Spring-Boot 使用 Jedis 操作 Redis

    背景: 1.Redis 之前学了个皮毛 还忘的差不多了,感觉公司项目中的Redis用的真的牛逼,so 需要深造. 2.有个同事在搞Jedis,勾起了我对知识的向往,不会用,但是很渴望. 过程: 1.改 ...

  10. Redis】Java中使用Jedis操作Redis(Maven导入包)、创建Redis连接池

    如果我们使用Java操作Redis, 需要确保已经安装了 redis 服务及 Java redis 驱动. Maven项目可以直接在pom.xml中加入jedis包驱动: <!-- https: ...

随机推荐

  1. web设计_9_CSS常用布局,响应式

    一个完整的页面和其中的组件该如何具备灵活性. 怎么样利用CSS来实现无论屏幕.窗口以及字体的大小如何变化,都可以自由扩展和收缩的分栏式页面. 要决定使用流动布局.弹性布局还是固定宽度的布局,得由项目的 ...

  2. rabbitMQ_routing(四)

    路由 本次我们将通过路由将信息发送到指定的队列中,将消息发送给指定的队列需要在转发器和队列之间建立一个routeKey 绑定 在以前的例子中,我们已经创建了绑定.你可能会记得如下代码: channel ...

  3. C++学习之路

    一.二分查找 1.binary_search:查找某个元素是否出现. a.函数模板:binary_search(arr,arr+size ,indx) b.参数说明: arr: 数组首地址 size: ...

  4. CF803D 题解

    题面 正解:一道二分大水题! A:为什么我得不到满分? B : 评测的系统不一样啊! A : 蛤? 正常情况下我们日常练习均使用的是windows系统,在windows下,string 本身是可以存储 ...

  5. Mysql之锁、事务绝版详解---干货!

    一 锁的分类及特性 数据库锁定机制简单来说,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则.对于任何一种数据库来说都需要有相应的锁定机制,所以MySQL自然也不能 ...

  6. python redis连接 有序集合去重

    # -*- coding: utf-8 -*- import redisfrom constant import redis_ip, redis_db, redis_pw, logger, redis ...

  7. 用scrapy爬取搜狗Lofter图片

    用scrapy爬取搜狗Lofter图片 # -*- coding: utf-8 -*- import json import scrapy from scrapy.http import Reques ...

  8. Unittest 支持 case 失败后自动截图功能的另外两种方式

    原生的unittest框架是不支持case失败后自动截图的功能的,网上看了大家的解决办法,大体上分为两种:1.要么加装饰器2.也有人封装断言这里我们看看还有没有其他的更加方便的方法值得大家一起探讨一下 ...

  9. hive数仓客户端界面工具

    1.Hive的官网上介绍了三个可以在Windows中通过JDBC连接HiveServer2的图形界面工具,包括:SQuirrel SQL Client.Oracle SQL Developer以及Db ...

  10. luogu1220_关路灯 区间dp

    传送门 区间dp f[i][j][state] : [i, j]区间 state=0 当前选i state = 1 当前选j 注意枚举的顺序 转移的设计时 在同时刻不在[i,j]区间里的数也要考虑 不 ...