一步一步学习Redis——Java连接Redis(Java中使用Redis命令)

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 一步一步学习Redis——Java连接Redis(Java中使用Redis命令)

文章目录:


1.安装与导入

1.1 测试代码

2.Java中使用Redis命令

2.1 对数据类型String进行简单操作 

2.2 对数据类型List进行简单操作

2.3 对数据类型Hash进行简单操作

2.4 对数据类型Set进行简单操作

2.5 对数据类型ZSet进行简单操作

2.6 Redis Java Keys 实例(对应Redis KEYS * 命令)

1.安装与导入

Java 中使用 Redis 前,我们需要确保已经安装了 redis 服务及 Java redis 驱动,且你的机器上能正常使用 Java 

我们需要下载 jedis.jar 驱动包:jedis-2.9.0.jar(并非最新版本)

写在前面:Redis中有哪些命令,与Java连接之后,这些命令自然就变成了相应的方法,供大家调用!!!


而后,打开编译器(我用的是Eclipse),新建一个Java Project,右键单击项目 → BuildPath → Add External Archives to Java Build Path,之后会出现如下界面:👇👇👇

完成以上步骤之后,我们写一个测试代码来检验一下Redis服务是否与Java环境连接成功!!!(在这之前,你需要打开Redis服务端)

1.1 测试代码

package study.redis.java;
import redis.clients.jedis.Jedis;
public class JedisDemo1 {
  public static void main(String[] args) {
    //连接本地的 Redis 服务
    Jedis jedis=new Jedis("localhost");
    //如果 Redis 服务设置了密码,需要添加下面这行代码
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    //调用ping()方法查看 Redis 服务是否运行
    System.out.println("Redis服务正在运行:" + jedis.ping());
  }
}

代码成功运行出如下结果,即连接成功!!! 

2.Java中使用Redis命令


2.1 对数据类型String进行简单操作 

package study.redis.java;
import redis.clients.jedis.Jedis;
public class JedisDemo2 {
  public static void main(String[] args) {
    Jedis jedis=new Jedis("localhost");
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    System.out.println("Redis服务正在运行:" + jedis.ping());
    //通过 Redis String字符串中的set命令设置相应的数据
    jedis.set("mykey","redis");
    //通过 Redis String字符串中的get命令获取相应的数据
    System.out.println("redis存储的字符串为:" + jedis.get("mykey"));
  }
}

2.2 对数据类型List进行简单操作

package study.redis.java;
import redis.clients.jedis.Jedis;
import java.util.List;
public class JedisDemo3 {
  public static void main(String[] args) {
    Jedis jedis=new Jedis("localhost");
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    System.out.println("Redis服务正在运行:" + jedis.ping());
    //通过 Redis List列表中的lpush命令设置相应的数据
    jedis.lpush("key","HTML");
    jedis.lpush("key","CSS");
    jedis.lpush("key","JavaScript");
    //同时存入Java list集合中
    List<String> list=jedis.lrange("key",0,2);
    for(int i=0;i<list.size();i++) {
      System.out.println("Redis列表项存储的数据为:" + list.get(i));
    }
    //通过 Redis List列表中的lrange命令获取相应的数据
    System.out.println("此时Redis列表项中的数据为:" + jedis.lrange("key",0,2));
  }
}

2.3 对数据类型Hash进行简单操作

package study.redis.java;
import redis.clients.jedis.Jedis;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class JedisDemo4 {
  public static void main(String[] args) {
    Jedis jedis=new Jedis("localhost");
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    System.out.println("Redis服务正在运行:" + jedis.ping());
    //通过 Redis Hash哈希中的hset命令设置相应的数据
    jedis.hset("key1","field1","封装");
    jedis.hset("key1","field2","继承");
    jedis.hset("key1","field3","多态");
    //转为Java Map集合
    Map<String,String> map=jedis.hgetAll("key1");
    Set<Map.Entry<String,String>> set=map.entrySet();
    Iterator<Map.Entry<String,String>> iterator=set.iterator();
    while(iterator.hasNext()) {
      Map.Entry<String,String> kv=iterator.next();
      Object keys=kv.getKey();
      Object values=kv.getValue();
      System.out.println("键:" + keys + ",值:" + values);
    }
    //通过 Redis Hash哈希中的hgetAll命令获取相应的数据
    System.out.println("此时Redis Hash中的数据为:" + jedis.hgetAll("key1"));
  }
}

2.4 对数据类型Set进行简单操作

package study.redis.java;
import redis.clients.jedis.Jedis;
import java.util.Set;
import java.util.Iterator;
public class JedisDemo5 {
  public static void main(String[] args) {
    Jedis jedis=new Jedis("localhost");
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    System.out.println("Redis服务正在运行:" + jedis.ping());
    //通过 Redis Set集合中的sadd命令设置相应的数据
    jedis.sadd("key2","huawei");
    jedis.sadd("key2","oppo");
    jedis.sadd("key2","vivo");
    //转为Java Set集合
    Set<String> hashset=jedis.smembers("key2");
    Iterator iterator=hashset.iterator();
    while(iterator.hasNext()) {
      System.out.println("Set集合中的数据为:" + iterator.next());
    }
    //通过 Redis Set集合中的smembers命令获取相应的数据
    System.out.println("此时Redis Set集合中的数据为:" + jedis.smembers("key2"));
  }
}

2.5 对数据类型ZSet进行简单操作

package study.redis.java;
import redis.clients.jedis.Jedis;
import java.util.Set;
import java.util.Iterator;
public class JedisDemo6 {
  public static void main(String[] args) {
    Jedis jedis=new Jedis("localhost");
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    System.out.println("Redis服务正在运行:" + jedis.ping());
    //通过 Redis ZSet集合中的zadd命令设置相应的数据
    jedis.zadd("key3",44,"red");
    jedis.zadd("key3",44,"green");
    jedis.zadd("key3",44,"blue");
    jedis.zadd("key3",1,"black");
    jedis.zadd("key3",80,"white");
    //转为Java Set集合
    Set<String> set=jedis.zrangeByScore("key3",0,100);
    Iterator iterator=set.iterator();
    while(iterator.hasNext()) {
      System.out.println("Set集合中的数据为:" + iterator.next());
    }
    //通过 Redis ZSet集合中的zrangeByScore命令获取相应的数据
    System.out.println("此时Redis ZSet集合中的数据为:" + jedis.zrangeByScore("key3",0,100));
  }
}

2.6 Redis Java Keys 实例(对应Redis KEYS * 命令)

package study.redis.java;
import redis.clients.jedis.Jedis;
import java.util.Set;
import java.util.Iterator;
public class JedisDemo7 {
  public static void main(String[] args) {
    Jedis jedis=new Jedis("localhost");
    jedis.auth("szh2656307671");
    System.out.println("连接成功");
    System.out.println("Redis服务正在运行:" + jedis.ping());
    //获取此时Redis数据库中的所有键
    Set<String> keys=jedis.keys("*");
    Iterator<String> iterator=keys.iterator();
    while(iterator.hasNext()) {
      System.out.println(iterator.next());
    }
    System.out.println("此时Redis数据库中存在这些键:" + jedis.keys("*"));
  }
}


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