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

本文涉及的产品
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操作客户端命令——列表操作与哈希操作》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下

相关文章
|
2月前
|
存储 SQL NoSQL
Redis-常用语法以及java互联实践案例
本文详细介绍了Redis的数据结构、常用命令及其Java客户端的使用,涵盖String、Hash、List、Set、SortedSet等数据类型及操作,同时提供了Jedis和Spring Boot Data Redis的实战示例,帮助开发者快速掌握Redis在实际项目中的应用。
245 1
Redis-常用语法以及java互联实践案例
|
2月前
|
存储 消息中间件 NoSQL
【Redis】常用数据结构之List篇:从常用命令到典型使用场景
本文将系统探讨 Redis List 的核心特性、完整命令体系、底层存储实现以及典型实践场景,为读者构建从理论到应用的完整认知框架,助力开发者在实际业务中高效运用这一数据结构解决问题。
|
2月前
|
存储 缓存 NoSQL
Redis基础命令与数据结构概览
Redis是一个功能强大的键值存储系统,提供了丰富的数据结构以及相应的操作命令来满足现代应用程序对于高速读写和灵活数据处理的需求。通过掌握这些基础命令,开发者能够高效地对Redis进行操作,实现数据存储和管理的高性能方案。
104 12
|
3月前
|
存储 缓存 人工智能
Redis六大常见命令详解:从set/get到过期策略的全方位解析
本文将通过结构化学习路径,帮助读者实现从命令语法掌握到工程化实践落地的能力跃迁,系统性提升 Redis 技术栈的应用水平。
|
4月前
|
NoSQL Redis
Lua脚本协助Redis分布式锁实现命令的原子性
利用Lua脚本确保Redis操作的原子性是分布式锁安全性的关键所在,可以大幅减少由于网络分区、客户端故障等导致的锁无法正确释放的情况,从而在分布式系统中保证数据操作的安全性和一致性。在将这些概念应用于生产环境前,建议深入理解Redis事务与Lua脚本的工作原理以及分布式锁的可能问题和解决方案。
186 8
|
5月前
|
缓存 监控 NoSQL
Redis 实操要点:Java 最新技术栈的实战解析
本文介绍了基于Spring Boot 3、Redis 7和Lettuce客户端的Redis高级应用实践。内容包括:1)现代Java项目集成Redis的配置方法;2)使用Redisson实现分布式可重入锁与公平锁;3)缓存模式解决方案,包括布隆过滤器防穿透和随机过期时间防雪崩;4)Redis数据结构的高级应用,如HyperLogLog统计UV和GeoHash处理地理位置。文章提供了详细的代码示例,涵盖Redis在分布式系统中的核心应用场景,特别适合需要处理高并发、分布式锁等问题的开发场景。
365 41
|
5月前
|
缓存 NoSQL Java
Java Redis 面试题集锦 常见高频面试题目及解析
本文总结了Redis在Java中的核心面试题,包括数据类型操作、单线程高性能原理、键过期策略及分布式锁实现等关键内容。通过Jedis代码示例展示了String、List等数据类型的操作方法,讲解了惰性删除和定期删除相结合的过期策略,并提供了Spring Boot配置Redis过期时间的方案。文章还探讨了缓存穿透、雪崩等问题解决方案,以及基于Redis的分布式锁实现,帮助开发者全面掌握Redis在Java应用中的实践要点。
284 6
|
6月前
|
Arthas 存储 监控
Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
381 8
|
6月前
|
存储 缓存 监控
Redis设计与实现——Redis命令参考与高级特性
Redis 是一个高性能的键值存储系统,支持丰富的数据类型(字符串、列表、哈希、集合等)和多种高级功能。本文档涵盖 Redis 的核心命令分类,包括数据类型操作、事务与脚本、持久化、集群管理、系统监控等。特别介绍了事务的原子性特性、Lua 脚本的执行方式及优势、排序机制、发布订阅模型以及慢查询日志和监视器工具的使用方法。适用于开发者快速掌握 Redis 常用命令及其应用场景,优化系统性能与可靠性。
|
存储 算法 Java
java- 分布式- 一致性哈希算法(1)
一致性哈希算法是分布式系统中常用的算法。比如,一个分布式的存储系统,要将数据存储到具体的节点上,如果采用普通的hash方法,将数据映射到具体的节点上,如key%N,key是数据的key,N是机器节点数,如果有一个机器加入或退出这个集群,则所有的数据映射都无效了,如果是持久化存储则要做数据迁移,如果是分布式缓存,则其他缓存就失效了。
1094 0