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

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Redis 版,经济版 1GB 1个月
简介: 【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
相关文章
|
13天前
|
存储 缓存 NoSQL
如何在Java中使用Redis
如何在Java中使用Redis
|
12天前
|
NoSQL Java Redis
软件开发常见流程之宝塔初始化安装环境配置,Lam前面不选,直接跳商城,在宝塔内点击软件商城,安Mysql5.7,安java项目管理器,安Ngnix最新版,安Redis
软件开发常见流程之宝塔初始化安装环境配置,Lam前面不选,直接跳商城,在宝塔内点击软件商城,安Mysql5.7,安java项目管理器,安Ngnix最新版,安Redis
|
12天前
|
缓存 NoSQL Redis
Java面试之redis篇
Java面试之redis篇
33 0
|
7天前
|
Java 数据格式
Java面试题:简述Java Socket编程的基本流程,包括客户端和服务器的创建与通信。
Java面试题:简述Java Socket编程的基本流程,包括客户端和服务器的创建与通信。
12 0
|
13天前
|
JSON NoSQL Java
Redis18的Java客户端-StringRedisTemplate,序列化存在的问题,使用StringRedisTemplate解决序列化的方法
Redis18的Java客户端-StringRedisTemplate,序列化存在的问题,使用StringRedisTemplate解决序列化的方法
|
13天前
|
JSON NoSQL Java
Redis17----Redis的java客户端-RedisTemplte的RedisSerializer,赋值的是虎哥,而取出来的是ROSE的原因,使用keys
Redis17----Redis的java客户端-RedisTemplte的RedisSerializer,赋值的是虎哥,而取出来的是ROSE的原因,使用keys
|
13天前
|
NoSQL Java Redis
Redis15-Redis的java客户端,认识SpringDataRedis
Redis15-Redis的java客户端,认识SpringDataRedis
|
存储 自然语言处理 Java
Elasticsearch: java客户端之AdminClient
Elasticsearch: java客户端之AdminClient
148 0
|
存储 自然语言处理 Java
Elasticsearch: java客户端之AdminClient
Elasticsearch: java客户端之AdminClient
232 0
Elasticsearch: java客户端之AdminClient
|
7天前
|
Java 调度
Java线程的六种状态
Java线程有六种状态: 初始(NEW)、运行(RUNNABLE)、阻塞(BLOCKED)、等待(WAITING)、超时等待(TIMED_WAITING)、终止(TERMINATED)。
22 1