Java 连接 Redis

  1. 引入 Maven 依赖
<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.3.0</version>
</dependency>

  1. Java 代码连接
// 编译以上 Java 程序,确保驱动包的路径是正确的。连接成功 / 服务正在运行: PONG
static String checkStart() {
// 连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost");
System.out.println("连接成功");
// 查看服务是否运行
return "服务正在运行:" + jedis.ping();
}

  1. Java 示例代码
import com.alibaba.fastjson.JSON;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class RedisTest {
@Test
public void main() {
Jedis jedis = checkStart();
System.out.println("删除所有数据库中的所有 key:" + jedis.flushAll());
// 操作字符串
// testString(jedis);
// 操作 Map
// testMap(jedis);
// 操作 List
// testList(jedis);
// 操作 Set
// testSet(jedis);
// 操作排序
// testSort(jedis);
}
/**
* redis 存储字符串
*/
public void testString(Jedis jedis) {
//----- 添加数据 ----------
jedis.set("name", "LouisVan"); // 向 key-->name 中放入了 value --> LouisVan
System.out.println(jedis.get("name")); // 执行结果:LouisVan
jedis.append("name", "is my lover"); // 拼接
System.out.println(jedis.get("name"));
jedis.del("name"); // 删除某个键
System.out.println(jedis.get("name"));
// 设置多个键值对
jedis.mset("name", "MapSheep", "age", "24", "email", "476777XXX@126.com");
jedis.incr("age"); // 进行加 1 操作
System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("email"));
}
/**
* redis 操作 Map
*/
private void testMap(Jedis jedis) {
//----- 添加数据 ----------
Map<String, String> map = new HashMap<>();
map.put("name", "LouisVan");
map.put("age", "22");
map.put("email", "123456@126.com");
jedis.hmset("user", map);
// 第一个参数是存入 redis 中 map 对象的 key,后面跟的是放入 map 中的对象的 key,后面的 key 可以跟多个,是可变参数
List<String> rsmap = jedis.hmget("user", "name", "age", "email");
System.out.println(JSON.toJSON(rsmap));
System.out.println("---------- 删除 map 中的某个键值 ----------");
jedis.hdel("user", "age");
System.out.println(jedis.hmget("user", "age")); // 因为删除了,所以返回的是 null
System.out.println(jedis.hlen("user")); // 返回 key 为 user 的键中存放的值的个数 2
System.out.println(jedis.exists("user"));// 是否存在 key 为 user 的记录 返回 true
System.out.println(jedis.hkeys("user"));// 返回 map 对象中的所有 key
System.out.println(jedis.hvals("user"));// 返回 map 对象中的所有 value
for (String key : jedis.hkeys("user")) {
System.out.println(key + ":" + jedis.hmget("user", key));
}
}
/**
* jedis 操作 List
*/
private void testList(Jedis jedis) {
// 开始前,先移除所有的内容
jedis.del("java framework");
System.out.println(jedis.lrange("java framework", 0, -1));
// 先向 key java framework 中存放三条数据
// 从下至上
jedis.lpush("java framework", "spring");
jedis.lpush("java framework", "struts");
jedis.lpush("java framework", "hibernate");
// 再取出所有数据 jedis.lrange 是按范围取出,
// 第一个是 key,第二个是起始位置,第三个是结束位置,jedis.llen 获取长度 -1 表示取得所有
System.out.println(jedis.lrange("java framework", 0, -1));
//[hibernate, struts, spring]
jedis.del("java framework");
// 从上至下
jedis.rpush("java framework", "spring");
jedis.rpush("java framework", "struts");
jedis.rpush("java framework", "hibernate");
System.out.println(jedis.lrange("java framework", 0, -1));
//[spring, struts, hibernate]
}
/**
* jedis 操作 Set
*/
private void testSet(Jedis jedis) {
// 添加
jedis.sadd("user", "liuling");
jedis.sadd("user", "xinxin");
jedis.sadd("user", "ling");
jedis.sadd("user", "zhangxinxin");
jedis.sadd("user", "who");
// 移除 who
jedis.srem("user", "who");
System.out.println(jedis.smembers("user"));// 获取所有加入的 value
System.out.println(jedis.sismember("user", "who"));// 判断 who 是否是 user 集合的元素
System.out.println(jedis.srandmember("user")); // 随机获取一个成员
System.out.println(jedis.scard("user"));// 返回集合的元素个数
}
private void testSort(Jedis jedis) {
//jedis 排序
// 注意,此处的 rpush 和 lpush 是 List 的操作。是一个双向链表(但从表现来看的)
jedis.del("a");// 先清除数据,再加入数据进行测试
jedis.rpush("a", "1");
jedis.lpush("a", "6");
jedis.lpush("a", "3");
jedis.lpush("a", "9");
System.out.println(jedis.lrange("a", 0, -1));// [9, 3, 6, 1]
System.out.println(jedis.sort("a")); //[1, 3, 6, 9] // 输入排序后结果
}
/**
* 编译以上 Java 程序,确保驱动包的路径是正确的。连接成功 / 服务正在运行: PONG
*
* @return Jedis jedis
*/
private Jedis checkStart() {
// 连接本地的 Redis 服务
Jedis jedis = new Jedis("localhost", 6379);
// 权限认证
// jedis.auth("admin");
System.out.println("连接成功");
return jedis;
}
}