【Redis】 Java操作客户端命令——列表操作与哈希操作

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【Redis】 Java操作客户端命令——列表操作与哈希操作

🍃前言

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

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

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

本篇演示以下两种用法:

  1. 列表操作
  2. 哈希表操作

🌴列表操作

准备工作代码如下:

public class ListDemo {
    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()){
            //清空redis数据库
            jedis.flushAll();
            //testLpushAndLpop(jedis);
            //testRpushAndRpop(jedis);
            //testLrange(jedis);
            //testBLpop(jedis);
            //testBRpop(jedis);
            //testLindex(jedis);
            //testLlen(jedis);
        }
    }
}

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

🚩lpush 和 lpop

  • lpush:将⼀个或者多个元素从左侧放⼊(头插)到 list 中。
  • lpoop:从 list 左侧取出元素(即头删)

测试代码如下:

public static void testLpushAndLpop(Jedis jedis) {
    System.out.println("测试 lpush 和 lpop");
    long n = jedis.lpush("key", "1", "2", "3", "4");
    System.out.println(n);
    String value = jedis.lpop("key");
    System.out.println(value);
    value = jedis.lpop("key");
    System.out.println(value);
    value = jedis.lpop("key");
    System.out.println(value);
    value = jedis.lpop("key");
    System.out.println(value);
    value = jedis.lpop("key");
    System.out.println(value);
}

执行结果如下:

🚩rpush 和 rpop

  • rpush:将⼀个或者多个元素从右侧放⼊(尾插)到 list 中
  • rpop:从 list 右侧取出元素(即尾删)

测试代码如下:

private static void testRpushAndRpop(Jedis jedis) {
    System.out.println("测试 rpush 与 rpop");
    long n = jedis.rpush("key", "1", "2", "3", "4");
    System.out.println(n);
    String value = jedis.rpop("key");
    System.out.println(value);
    value = jedis.rpop("key");
    System.out.println(value);
    value = jedis.rpop("key");
    System.out.println(value);
    value = jedis.rpop("key");
    System.out.println(value);
    value = jedis.rpop("key");
    System.out.println(value);
}

执行结果如下:

🚩lrange

  • lrange:获取从 start 到 end 区间的所有元素,左闭右闭。

测试代码如下:

private static void testLrange(Jedis jedis) {
    jedis.rpush("key", "1", "2", "3", "4");
    List<String> values = jedis.lrange("key", 1, 3);
    System.out.println(values);
}

执行结果如下:

🚩bloop

  • bloop:lpoop的阻塞版本,返回值 List 是个⼆元组.。[0] 表⽰ key, [1] 表⽰ value

超时时间设为 0 表⽰死等,在执⾏同时,起⼀个 redis-cli,插⼊数据,即可看到 blpop的返回结果

测试代码如下:

private static void testBLpop(Jedis jedis) {
    System.out.println("测试 bloop");
    while (true) {
        List<String> values = jedis.blpop(0, "key");
        System.out.println(values);
    }
}

另起一个客户端插入数据

执行结果如下:

🚩brpop

使用方式与bloop类似

测试代码如下:

private static void testBRpop(Jedis jedis) {
    System.out.println("开始调⽤ brpop");
    while (true) {
        List<String> values = jedis.brpop(0, "key");
        System.out.println(values);
    }
}

调用Redis客户端

执行结果如下:

🚩lindex

  • lindex:获取从左数第 index 位置的元素

测试代码如下:

private static void testLindex(Jedis jedis) {
    System.out.println("测试 lindex");
    jedis.rpush("key", "1", "2", "3", "4");
    String value = jedis.lindex("key", 2);
    System.out.println(value);
}

执行结果

🚩linsert

  • linsert:通过 ListPosition.BEFORE 和 ListPosition.AFTER 标识插⼊位置

测试代码如下:

private static void testLinsert(Jedis jedis) {
    jedis.rpush("key", "a", "b", "c", "d");
    jedis.linsert("key", ListPosition.BEFORE, "c", "100");
    List<String> values = jedis.lrange("key", 0, -1);
    System.out.println(values);
}

执行结果如下:

🚩llen

  • llen:获取 list 的长度

测试代码如下:

private static void testLlen(Jedis jedis) {
    jedis.rpush("key", "a", "b", "c", "d");
    long n = jedis.llen("key");
    System.out.println(n);
}

执行结果如下:

🎋哈希操作

准备工作代码如下:

public class HashDemo {
    public static void main(String[] args) {
        JedisPool jedisPool = new JedisPool("tcp://127.0.0.1:8888");
        try (Jedis jedis = jedisPool.getResource()) {
            //清空redis数据库
            jedis.flushAll();
            //以下为测试方法
            //testHsetAndHget(jedis);
            //testHexistsAndHdel(jedis);
            //testHkeysAndHvalues(jedis);
            //testHmget(jedis);
            //testHIncrByAndHincrByFloat(jedis);
        }
    }
}

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

🚩hset 和 hget

  • hset:设置 hash 中指定的字段(field)的值(value)。
  • hget:获取hash中指定字段的值

测试代码如下:

private static void testHsetAndHget(Jedis jedis) {
    System.out.println("测试 hset and hget");
    jedis.hset("key", "name", "zhangsan");
    jedis.hset("key", "age", "20");
    String name = jedis.hget("key", "name");
    System.out.println(name);
    String age = jedis.hget("key", "age");
    System.out.println(age);
}

执行结果如下:

🚩hexists 和 hdel

  • hexists:判断 hash 中是否有指定的字段。
  • hdel:删除 hash 中指定的字段

测试代码如下:

private static void testHexistsAndHdel(Jedis jedis) {
    System.out.println("测试hexists 和 hdel");
    jedis.hset("key", "name", "zhangsan");
    boolean ok = jedis.hexists("key", "name");
    System.out.println(ok);
    jedis.hdel("key", "name");
    ok = jedis.hexists("key", "name");
    System.out.println(ok);
}

执行结果如下:

🚩hkeys 和 hvals

  • hkeys:获取 hash 所有字段
  • hvals:获取 hash 中的所有的值

测试代码如下:

private static void testHkeysAndHvalues(Jedis jedis) {
    System.out.println("测试 hkeys 和 hvalues");
    jedis.hset("key", "name", "zhangsan");
    jedis.hset("key", "age", "20");
    Set<String> keys = jedis.hkeys("key");
    System.out.println(keys);
    List<String> values = jedis.hvals("key");
    System.out.println(values);
}

执行结果如下:

🚩hmget

  • hmget:⼀次获取 hash 中多个字段的值

测试代码:

private static void testHmget(Jedis jedis) {
    System.out.println("测试 hmget");
    jedis.hset("key", "name", "zhangsan");
    jedis.hset("key", "age", "20");
    List<String> values = jedis.hmget("key", "name", "age");
    System.out.println(values);
}

执行结果如下:

🚩hlen

  • hlen:获取 hash 中的所有字段的个数。

测试代码如下:

private static void testHlen(Jedis jedis) {
    System.out.println("测试 hlen");
    jedis.hset("key", "name", "zhangsan");
    jedis.hset("key", "age", "20");
    long n = jedis.hlen("key");
    System.out.println(n);
}

执行结果如下:

🚩hincrby 和 hincrbyfloat

  • hincrby:将 hash 中字段对应的数值添加指定的值
  • hincrbyfloat:hincrby的浮点数版本

测试代码如下:

private static void testHIncrByAndHincrByFloat(Jedis jedis) {
    System.out.println("测试 hincrby 与 hincrbyfloat");
    jedis.hset("key", "age", "20");
    long n = jedis.hincrBy("key", "age", 10);
    System.out.println(n);
    String value = jedis.hget("key", "age");
    System.out.println(value);
    double dn = jedis.hincrByFloat("key", "age", 0.5);
    System.out.println(dn);
    value = jedis.hget("key", "age");
    System.out.println(value);
}

执行结果如下:

⭕总结

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

相关文章
|
13天前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
149 5
|
5月前
|
存储 缓存 监控
Redis设计与实现——Redis命令参考与高级特性
Redis 是一个高性能的键值存储系统,支持丰富的数据类型(字符串、列表、哈希、集合等)和多种高级功能。本文档涵盖 Redis 的核心命令分类,包括数据类型操作、事务与脚本、持久化、集群管理、系统监控等。特别介绍了事务的原子性特性、Lua 脚本的执行方式及优势、排序机制、发布订阅模型以及慢查询日志和监视器工具的使用方法。适用于开发者快速掌握 Redis 常用命令及其应用场景,优化系统性能与可靠性。
|
1月前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
78 12
|
1月前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
2月前
|
存储 缓存 人工智能
Redis六大常见命令详解:从set/get到过期策略的全方位解析
本文将通过结构化学习路径,帮助读者实现从命令语法掌握到工程化实践落地的能力跃迁,系统性提升 Redis 技术栈的应用水平。
|
5月前
|
人工智能 Java API
MCP客户端调用看这一篇就够了(Java版)
本文详细介绍了MCP(Model Context Protocol)客户端的开发方法,包括在没有MCP时的痛点、MCP的作用以及如何通过Spring-AI框架和原生SDK调用MCP服务。文章首先分析了MCP协议的必要性,接着分别讲解了Spring-AI框架和自研SDK的使用方式,涵盖配置LLM接口、工具注入、动态封装工具等步骤,并提供了代码示例。此外,还记录了开发过程中遇到的问题及解决办法,如版本冲突、服务连接超时等。最后,文章探讨了框架与原生SDK的选择,认为框架适合快速构建应用,而原生SDK更适合平台级开发,强调了两者结合使用的价值。
7754 33
MCP客户端调用看这一篇就够了(Java版)
|
3月前
|
NoSQL Redis
Lua脚本协助Redis分布式锁实现命令的原子性
利用Lua脚本确保Redis操作的原子性是分布式锁安全性的关键所在,可以大幅减少由于网络分区、客户端故障等导致的锁无法正确释放的情况,从而在分布式系统中保证数据操作的安全性和一致性。在将这些概念应用于生产环境前,建议深入理解Redis事务与Lua脚本的工作原理以及分布式锁的可能问题和解决方案。
154 8
|
5月前
|
存储 网络协议 Java
Java获取客户端IP问题:返回127.0.0.1
总结:要解决Java获取客户端IP返回127.0.0.1的问题,首先要找出原因,再采取合适的解决方案。请参考上述方案来改进代码,确保在各种网络环境下都能正确获取客户端IP地址。希望本文对您有所帮助。
367 25
|
5月前
|
存储 缓存 NoSQL
Redis中的常用命令-get&set&keys&exists&expire&ttl&type的详细解析
总的来说,这些Redis命令提供了处理存储在内存中的键值对的便捷方式。通过理解和运用它们,你可以更有效地在Redis中操作数据,使其更好地服务于你的应用。
382 17
|
5月前
|
Arthas 存储 监控
Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
312 8