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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【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操作客户端命令——集合操作与有序集合操作》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
7天前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
22 1
|
10天前
|
存储 NoSQL Java
Redis命令:列表模糊删除详解
通过本文的介绍,我们详细探讨了如何在Redis中实现列表的模糊删除。虽然Redis没有直接提供模糊删除命令,但可以通过组合使用 `LRANGE`和 `LREM`命令,并在客户端代码中进行模糊匹配,来实现这一功能。希望本文能帮助你在实际应用中更有效地操作Redis列表。
22 0
|
1月前
|
缓存 NoSQL 测试技术
Redis如何解决频繁的命令往返造成的性能瓶颈!
Redis如何解决频繁的命令往返造成的性能瓶颈!
|
1月前
|
缓存 NoSQL Java
Java中redis面试题
Java中redis面试题
34 1
|
20天前
|
存储 NoSQL Java
Java 使用 Redis
10月更文挑战第22天
25 0
|
27天前
|
NoSQL Redis 数据安全/隐私保护
Redis 命令
10月更文挑战第15天
25 0
|
存储 NoSQL 关系型数据库
Redis命令——有序集合(sorted set)
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。 不同的是每个元素都会关联一个double类型的分数。
1839 0
|
存储 NoSQL Redis
redis必杀命令:有序集合(sorted set)
题记 Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。 不同的是每个元素都会关联一个double类型的分数。
922 0
|
1月前
|
消息中间件 缓存 NoSQL
Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
74 6
|
6天前
|
缓存 NoSQL 关系型数据库
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
本文详解缓存雪崩、缓存穿透、缓存并发及缓存预热等问题,提供高可用解决方案,帮助你在大厂面试和实际工作中应对这些常见并发场景。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题