【Redis】 Java操作客户端命令——集合操作与有序集合操作

简介: 【Redis】 Java操作客户端命令——集合操作与有序集合操作

🍃前言

本篇文章重点是,介绍一些Java 操作 Redis 的常见命令的使用。

总体分为以下6个部分进行介绍:

  1. 基础操作
  2. 字符串操作
  3. 列表操作
  4. 哈希表操作
  5. 集合操作
  6. 有序集合操作

本篇演示以下两种用法:

  1. 集合操作
  2. 有序集合操作

🌳集合操作

准备工作代码如下:

public class SetDemo {
    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            //清空数据库
            jedis.flushAll();
            //测试代码如下
            //testSaddAndSmembers(jedis);
            //testSremAndSismember(jedis);
            //testScard(jedis);
            //testSinter(jedis);
            //testSunion(jedis);
            //testSdiff(jedis);
        }
    }
}

这里博主只展示如何使用 Java 操作完成这些命令操作,如果有小伙伴对这部分命令作用不了解,可以参考博主写的【Redis】 关于 Redis 集合类型

🚩sadd 和 smembers

  • sadd:将⼀个或者多个元素添加到 set 中。注意,重复的元素⽆法添加到 set 中。
  • smembers:获取⼀个 set 中的所有元素,注意,元素间的顺序是⽆序的。

测试代码如下:

private static void testSaddAndSmembers(Jedis jedis) {
    System.out.println("测试 sadd 和 smembers");
    jedis.sadd("key", "aaa", "bbb", "ccc");
    Set<String> members = jedis.smembers("key");
    System.out.println(members);
}

执行结果如下:

🚩srem 和 sismember

  • srem:将指定的元素从 set 中删除。
  • sismember:判断⼀个元素在不在 set 中。

测试代码如下:

private static void testSremAndSismember(Jedis jedis) {
    System.out.println("测试 srem 和 sismember");
    jedis.sadd("key", "aaa", "bbb", "ccc");
    boolean ok = jedis.sismember("key", "aaa");
    System.out.println(ok);
    long n = jedis.srem("key", "aaa", "bbb");
    System.out.println(n);
    ok = jedis.sismember("key", "aaa");
    System.out.println(ok);
}

执行结果如下:

🚩scard

  • scard:获取⼀个 set 的基数(cardinality),即 set 中的元素个数

测试代码如下:

private static void testScard(Jedis jedis) {
    System.out.println("测试 scard");
    jedis.sadd("key", "aaa", "bbb", "ccc");
    long n = jedis.scard("key");
    System.out.println(n);
}

执行结果如下:

🚩sinter

  • sinter:获取给定 set 的交集中的元素

测试代码如下:

private static void testSinter(Jedis jedis) {
    System.out.println("测试 sinter");
    jedis.sadd("key1", "aaa", "bbb", "ccc");
    jedis.sadd("key2", "aaa", "bbb", "ddd");
    Set<String> results = jedis.sinter("key1", "key2");
    System.out.println(results);
}

执行结果如下:

🚩sunion

  • sunion:获取给定 set 的并集中的元素。

测试代码如下:

private static void testSunion(Jedis jedis) {
    System.out.println("测试 sunion");
    jedis.sadd("key1", "aaa", "bbb", "ccc");
    jedis.sadd("key2", "aaa", "bbb", "ddd");
    Set<String> results = jedis.sunion("key1", "key2");
    System.out.println(results);
}

执行结果如下:

🚩sdiff

  • sdifff:获取给定 set 的差集中的元素

测试代码如下:

private static void testSdiff(Jedis jedis) {
    System.out.println("测试 sdiff");
    jedis.sadd("key1", "aaa", "bbb", "ccc");
    jedis.sadd("key2", "aaa", "bbb", "ddd");
    Set<String> results = jedis.sdiff("key1", "key2");
    System.out.println(results);
}

执行结果如下:

🌲有序集合操作

准备测试代码如下:

public class ZsetDemo {
    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            //删除数据库
            jedis.flushAll();
            //测试代码如下
            //testZaddAndZrange(jedis);
            //testZremAndZcard(jedis);
            //testZcount(jedis);
            //testZpopmaxAndZpopmin(jedis);
            //testZscore(jedis);
            //testZincrby(jedis);
            //testZinterstore(jedis);
            //testZunionstore(jedis);
        }
    }
}

这里博主只展示如何使用 Java 操作完成这些命令操作,如果有小伙伴对这部分命令作用不了解,可以参考博主写的 【Redis】 关于 Redis 有序集合类型

🚩zadd 和 zrange

  • zadd:添加或者更新指定的元素以及关联的分数到 zset 中,分数应该符合 double类型,+inf/-inf 作为正负极限也是合法的。
  • zrange:返回指定区间⾥的元素,分数按照升序。带上 WITHSCORES 可以把分数也返回。

测试代码如下:

private static void testZaddAndZrange(Jedis jedis) {
    System.out.println("测试 zadd 和 zrange");
    jedis.zadd("key", 100, "吕布");
    jedis.zadd("key", 98, "赵云");
    jedis.zadd("key", 95, "典⻙");
    jedis.zadd("key", 92, "关⽻");
    jedis.zadd("key", 70, "刘备");
    List<String> members = jedis.zrange("key", 0, 4);
    System.out.println(members);
    List<Tuple> membersWithScore = jedis.zrangeWithScores("key", 0, 4);
    System.out.println(membersWithScore);
}

执行结果如下:

🚩zrem 和 zcard

  • zrem:删除指定元素
  • zcard:获取⼀个 zset 的基数(cardinality),即 zset 中的元素个数

测试代码如下:

private static void testZremAndZcard(Jedis jedis) {
    System.out.println("测试 zrem 和 zcard");
    jedis.zadd("key", 100, "吕布");
    jedis.zadd("key", 98, "赵云");
    jedis.zadd("key", 95, "典⻙");
    jedis.zadd("key", 92, "关⽻");
    jedis.zadd("key", 70, "刘备");
    long n = jedis.zcard("key");
    System.out.println(n);
    n = jedis.zrem("key", "吕布", "赵云");
    System.out.println(n);
    n = jedis.zcard("key");
    System.out.println(n);
}

执行结果如下:

🚩zcount

  • zcount:获取指定分数区间中的元素个数,闭区间

测试代码如下:

private static void testZcount(Jedis jedis) {
    System.out.println("测试 zount ");
    jedis.zadd("key", 100, "吕布");
    jedis.zadd("key", 98, "赵云");
    jedis.zadd("key", 95, "典⻙");
    jedis.zadd("key", 92, "关⽻");
    jedis.zadd("key", 70, "刘备");
    long n = jedis.zcount("key", 92, 98);
    System.out.println(n);
}

执行结果如下:

🚩zpopmax 和 zpopmin

  • zpopmax:删除并返回分数最⾼的 元素与分数
  • zpopmin:删除并返回分数最低的 元素与分数
private static void testZpopmaxAndZpopmin(Jedis jedis) {
    System.out.println("测试 zpopmax 和 zpopmin");
    jedis.zadd("key", 100, "吕布");
    jedis.zadd("key", 98, "赵云");
    jedis.zadd("key", 95, "典⻙");
    jedis.zadd("key", 92, "关⽻");
    jedis.zadd("key", 70, "刘备");
    Tuple tuple = jedis.zpopmax("key");
    System.out.println("最大" + tuple);
    tuple = jedis.zpopmin("key");
    System.out.println("最小" + tuple);
}

执行结果如下:

🚩zrank

  • 返回指定元素的排名,升序。

测试代码如下:

private static void testZrank(Jedis jedis) {
    System.out.println("测试 zrank");
    jedis.zadd("key", 100, "吕布");
    jedis.zadd("key", 98, "赵云");
    jedis.zadd("key", 95, "典⻙");
    jedis.zadd("key", 92, "关⽻");
    jedis.zadd("key", 70, "刘备");
    long n = jedis.zrank("key", "赵云");
    System.out.println(n);
    n = jedis.zrevrank("key", "赵云");
    System.out.println(n);
}

执行结果如下:

🚩zcore

  • zcore:返回指定元素的分数

测试代码如下:

private static void testZscore(Jedis jedis) {
    System.out.println("测试 zscore");
    jedis.zadd("key", 100, "吕布");
    jedis.zadd("key", 98, "赵云");
    jedis.zadd("key", 95, "典⻙");
    jedis.zadd("key", 92, "关⽻");
    jedis.zadd("key", 70, "刘备");
    double score = jedis.zscore("key", "赵云");
    System.out.println(score);
}

执行结果如下:

🚩zincrby

  • zincrby:为指定的元素的关联分数添加指定的分数值

测试代码如下:

private static void testZincrby(Jedis jedis) {
    System.out.println("测试 zincrby");
    jedis.zadd("key", 100, "吕布");
    double n = jedis.zincrby("key", 10, "吕布");
    System.out.println(n);
    n = jedis.zincrby("key", -20, "吕布");
    System.out.println(n);
}

执行结果如下:

🚩zinterstore

  • zinterstore:求出给定有序集合中元素的交集并保存进⽬标有序集合中,在合并过程中以元素为单位进⾏合并,元素对应的分数按照不同的聚合⽅式和权重得到新的分数。

测试代码如下:

private static void testZinterstore(Jedis jedis) {
    System.out.println("测试 zinterstore");
    jedis.zadd("key1", 100, "吕布");
    jedis.zadd("key1", 98, "赵云");
    jedis.zadd("key1", 95, "典⻙");
    jedis.zadd("key2", 100, "吕布");
    jedis.zadd("key2", 98, "赵云");
    jedis.zadd("key2", 92, "关⽻");
    long n = jedis.zinterstore("key3", "key1", "key2");
    System.out.println(n);
    List<Tuple> tuples = jedis.zrangeWithScores("key3", 0, -1);
    System.out.println(tuples);
}

执行结果如下:

🚩zunionstore

  • zunionstore:求出给定有序集合中元素的并集并保存进⽬标有序集合中,在合并过程中以元素为单位进⾏合并,元素对应的分数按照不同的聚合⽅式和权重得到新的分数。

测试代码如下:

private static void testZunionstore(Jedis jedis) {
    System.out.println("测试 zunionstore ");
    jedis.zadd("key1", 100, "吕布");
    jedis.zadd("key1", 98, "赵云");
    jedis.zadd("key1", 95, "典⻙");
    jedis.zadd("key2", 100, "吕布");
    jedis.zadd("key2", 98, "赵云");
    jedis.zadd("key2", 92, "关⽻");
    long n = jedis.zunionstore("key3", "key1", "key2");
    System.out.println(n);
    List<Tuple> tuples = jedis.zrangeWithScores("key3", 0, -1);
    System.out.println(tuples);
}

执行结果如下:

⭕总结

关于《【Redis】 Java操作客户端命令——集合操作与有序集合操作》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下

相关文章
|
8月前
|
存储 SQL NoSQL
Redis-常用语法以及java互联实践案例
本文详细介绍了Redis的数据结构、常用命令及其Java客户端的使用,涵盖String、Hash、List、Set、SortedSet等数据类型及操作,同时提供了Jedis和Spring Boot Data Redis的实战示例,帮助开发者快速掌握Redis在实际项目中的应用。
666 1
Redis-常用语法以及java互联实践案例
|
11月前
|
缓存 监控 NoSQL
Redis 实操要点:Java 最新技术栈的实战解析
本文介绍了基于Spring Boot 3、Redis 7和Lettuce客户端的Redis高级应用实践。内容包括:1)现代Java项目集成Redis的配置方法;2)使用Redisson实现分布式可重入锁与公平锁;3)缓存模式解决方案,包括布隆过滤器防穿透和随机过期时间防雪崩;4)Redis数据结构的高级应用,如HyperLogLog统计UV和GeoHash处理地理位置。文章提供了详细的代码示例,涵盖Redis在分布式系统中的核心应用场景,特别适合需要处理高并发、分布式锁等问题的开发场景。
613 42
|
11月前
|
缓存 NoSQL Java
Java Redis 面试题集锦 常见高频面试题目及解析
本文总结了Redis在Java中的核心面试题,包括数据类型操作、单线程高性能原理、键过期策略及分布式锁实现等关键内容。通过Jedis代码示例展示了String、List等数据类型的操作方法,讲解了惰性删除和定期删除相结合的过期策略,并提供了Spring Boot配置Redis过期时间的方案。文章还探讨了缓存穿透、雪崩等问题解决方案,以及基于Redis的分布式锁实现,帮助开发者全面掌握Redis在Java应用中的实践要点。
616 6
|
Arthas 存储 监控
Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
929 8
|
NoSQL Java API
在Java环境下如何进行Redis数据库的操作
总的来说,使用Jedis在Java环境下进行Redis数据库的操作,是一种简单而高效的方法。只需要几行代码,就可以实现复杂的数据操作。同时,Jedis的API设计得非常直观,即使是初学者,也可以快速上手。
467 94
|
前端开发 Java Unix
Java命令参数说明大全
序言:  Java 在运行已编译完成的类时,是通过 java 虚拟机来装载和执行的,java 虚拟机通过操作系统命令 JAVA_HOME/bin/java –option 来启动,-option 为虚拟机参数,JAVA_HOME 为JDK安装路径,通过这些参数可对虚拟机的运行状态进行调整,掌握参数的含义可对虚拟机的运行模式有更深入理解。
1196 0
|
7月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
396 1
|
7月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
368 1
|
8月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
354 0