【redis】在 Spring中操作 Redis
文章目录
- 基础设置
- 依赖
- StringRedisTemplate
- 库的封装
- 运行
- String
- List
- 删库
- Set
- Hash
- Zset
基础设置
依赖
- 需要选择这个依赖
StringRedisTemplate
// 后续 redis 测试的各种方法,都通过这个 Controller 提供的 http 接口来触发
@RestController
public class MyController {
private StringRedisTemplate redisTemplate;
}
前面使用 Jedis
,是通过 Jedis
对象里的各种方法来操作 Redis
的。此处 Spring
中则是通过 StringRedisTemplate
来操作 Redis
的
- 最原始提供的类是
RedisTemplate
类,StringRedisTemplate
是其子类,专门用来处理文本数据 - 这个类提供的方法,相比与
Jedis
中的各种方法,还是存在较大差异
库的封装
此处 RedisTemplate
是把这些 redis
的方法,分成了几个类别,分门别类的来组织的
- 做了进一步封装
- 比如
opsForList
就是得到了一个专门来操作List
的对象 - 比如
opsForSet
就是得到了一个专门来操作Set
的对象
- 比如
- 后续该类型涉及到的相关操作,都是以这个对象来组织的
此处提供的一些接口风格,和原生的
Redis
命令就有一定的差异了
- 初心是希望,通过上述的重新封装,让接口用起来更简单
运行
String
// 后续 redis 测试的各种方法,都通过这个 Controller 提供的 http 接口来触发
@RestController
public class MyController {
@Autowired
private StringRedisTemplate redisTemplate;
@GetMapping("/testString")
@ResponseBody
public String testString(){
redisTemplate.opsForValue().set("key1", "111");
redisTemplate.opsForValue().set("key2", "222");
redisTemplate.opsForValue().set("key3", "3");
String value = redisTemplate.opsForValue().get("key1");
System.out.println("value: " + value);
return "OK";
}
}
启动服务器之后,在浏览器上输入对应的路径
随后观察日志:
List
删库
RedisTemplate
留了一个后手,让我们随时能够执行到 Redis
的原生命令—— execute
方法
- 相当于函数式接口,也就是回调函数。就在回调里,写我们要执行的
Redis
命令,这个回调就会被RedisTemplate
执行 - 这里的
RedisConnection
就代表了Redis
连接,对标Jedis
对象
@GetMapping("/testList")
@ResponseBody
public String testList() {
// 清楚之前的数据
redisTemplate.execute((RedisConnection connection) -> {
connection.flushAll();
return null;
});
redisTemplate.opsForList().leftPush("key1", "111");
redisTemplate.opsForList().leftPush("key2", "222");
redisTemplate.opsForList().leftPush("key3", "333");
System.out.println(redisTemplate.opsForList().leftPop("key1"));
System.out.println(redisTemplate.opsForList().leftPop("key2"));
System.out.println(redisTemplate.opsForList().leftPop("key3"));
return "OK";
}
connection.
里面都是我们熟悉的原生命令
Set
@ResponseBody
@GetMapping("/testSet")
public String testSet() {
redisTemplate.execute((RedisConnection connetion) -> {
connetion.flushAll();
return null;
});
redisTemplate.opsForSet().add("key", "111", "222", "333");
Set<String> result = redisTemplate.opsForSet().members("key");
System.out.println(result);
Boolean exists = redisTemplate.opsForSet().isMember("key", "111");
System.out.println("exists:" + exists);
Long count = redisTemplate.opsForSet().size("key");
System.out.println("count: " + count);
redisTemplate.opsForSet().remove("key", "111", "222");
result = redisTemplate.opsForSet().members("key");
System.out.println("result: " + result);
return "OK";
}
Hash
@ResponseBody
@GetMapping("/testHash")
public String testHash() {
redisTemplate.execute((RedisConnection connection) -> {
connection.flushAll();
return null;
});
redisTemplate.opsForHash().put("key1", "field1", "111");
redisTemplate.opsForHash().put("key2", "field2", "222");
redisTemplate.opsForHash().put("key3", "field3", "333");
String value = (String) redisTemplate.opsForHash().get("key1", "field1");
System.out.println("value: " + value);
Boolean exists = redisTemplate.opsForHash().hasKey("key1", "field1");
System.out.println("exists:" + exists);
redisTemplate.opsForHash().delete("key1", "dield1", "field2");
Long size = redisTemplate.opsForHash().size("key");
System.out.println("size: " + size);
return "OK";
}
Zset
@GetMapping("/testZset")
@ResponseBody
public String testZset(){
redisTemplate.execute((RedisConnection connection) -> {
connection.flushAll();
return null;
});
redisTemplate.opsForZSet().add("key1", "111", 100);
redisTemplate.opsForZSet().add("key2", "222", 98);
redisTemplate.opsForZSet().add("key3", "333", 95);
Set<String> members = redisTemplate.opsForZSet().range("key1", 0, -1);
System.out.println("members: " + members);
Set<ZSetOperations.TypedTuple<String>> membersWithSocres = redisTemplate.opsForZSet().rangeWithScores("key", 0, -1);
System.out.println("membersWithScores: " + membersWithSocres);
Double score = redisTemplate.opsForZSet().score("key1", "111");
System.out.println("score: " + score);
Long size = redisTemplate.opsForZSet().size("key1");
System.out.println("size: " + size);
Long rank = redisTemplate.opsForZSet().rank("key1", "111");
System.out.println("rank: " + rank);
return "OK";
}