【redis】在 Spring中操作 Redis

devtools/2025/3/25 14:05:40/

文章目录

  • 基础设置
    • 依赖
    • StringRedisTemplate
    • 库的封装
  • 运行
    • String
    • List
      • 删库
    • Set
    • Hash
    • Zset

基础设置

依赖

  • 需要选择这个依赖 image.png|322

StringRedisTemplate

// 后续 redis 测试的各种方法,都通过这个 Controller 提供的 http 接口来触发  
@RestController  
public class MyController {  private StringRedisTemplate redisTemplate;  
}

前面使用 Jedis,是通过 Jedis 对象里的各种方法来操作 Redis 的。此处 Spring 中则是通过 StringRedisTemplate 来操作 Redis

  • 最原始提供的类是 RedisTemplate 类,StringRedisTemplate 是其子类,专门用来处理文本数据
  • 这个类提供的方法,相比与 Jedis 中的各种方法,还是存在较大差异

库的封装

image.png|290

此处 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";  }  
}

启动服务器之后,在浏览器上输入对应的路径 image.png|334
随后观察日志:image.png|358

List

删库

RedisTemplate 留了一个后手,让我们随时能够执行到 Redis 的原生命令—— execute 方法image.png

  • 相当于函数式接口,也就是回调函数。就在回调里,写我们要执行的 Redis 命令,这个回调就会被 RedisTemplate 执行image.png
  • 这里的 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";  
}   

image.png|319
image.png|309

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";  
}

image.png|402
image.png|415

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";  
}

image.png|306


http://www.ppmy.cn/devtools/169229.html

相关文章

3.21学习总结 Java字符串+Static关键字

this关键字&#xff1a; 作用&#xff1a;区别局部变量和成员变量 本质&#xff1a;所在方法调用者的地址值 就近原则 API StringBulider 使用场景&#xff1a;1.字符串的拼接&#xff0c;2.字符串的反转。 练习题&#xff1a; 链式编程&#xff1a; 在调用一个方法的时候…

【Bluebell】项目总结:基于 golang 的前后端分离 web 项目实战

文章目录 Bluebell 项目总结&#xff1a;基于 golang 的前后端分离 web 项目实战项目入口&#xff1a;先从 main 函数入手准备工作&#xff1a;加载配置、初始化日志、初始化数据库等加载配置初始化日志初始化 MySQL 连接初始化 Redis 连接初始化雪花算法初始化 GIN 框架内置的…

解释什么是受控组件和非受控组件

在 React 中&#xff0c;表单元素的管理和处理是一个重要的主题。理解受控组件和非受控组件之间的区别&#xff0c;对构建高效、可维护的用户界面至关重要。本文将深入探讨这两种组件的定义、优缺点、使用场景以及最佳实践。 1. 什么是受控组件&#xff1f; 1.1 定义 受控组…

无服务器架构将淘汰运维?2025年云计算形态预测

无服务器架构将淘汰运维&#xff1f;2025年云计算形态预测 随着云计算技术的快速演进&#xff0c;**无服务器架构&#xff08;Serverless&#xff09;**正逐步改变企业的开发与运维模式。无服务器架构是否会彻底淘汰传统运维&#xff1f;2025年的云计算格局将如何演变&#xf…

HTML5前端第七章节

本章节为前端网页页面实战&#xff0c;包含我们之前所学的全部内容 一.创建项目目录 1.网站根目录&#xff1a; 网站根目录指的是存放网站的第一层文件夹&#xff0c;内部包含当前网站的所有素材&#xff0c;包含HTML&#xff0c;CSS&#xff0c;需要的素材图片等等 2.根目录…

双核锁步技术在汽车芯片软错误防护中的应用详解

摘要 本文深入探讨了双核锁步技术在保障汽车芯片安全性中的应用。文章首先分析了国产车规芯片在高安全可靠领域面临的软错误难点及攻克方向&#xff0c;然后详细介绍了双核锁步技术的基本原理及其在汽车芯片防软错误的重要性。通过对比国内外多家厂商的芯片技术&#xff0c;分析…

HAl库开发中断方式接收Can报文的详细流程

下面给出一个基于 HAL 库的中断方式接收 CAN 报文的详细流程说明&#xff0c;描述每一步的硬件配置、软件调用和中断处理机制&#xff0c;而不涉及具体代码细节&#xff0c;只讲解整体原理和步骤&#xff1a; 在使用 HAL 库时&#xff0c;不需要手动清除中断标志位。原因如下&…

DigitalFoto公司如何用日事清流程管理工具实现任务优先级与状态可视化?

一、业务介绍 在DigitalFoto&#xff0c;设计和制造先进的摄影器材&#xff0c;如稳定器、灯光设备和支架&#xff0c;是日常工作的核心。公司的业务模式包括为其他品牌设计和制造定制产品&#xff0c;无论是作为OEM还是ODM。这样的多样化业务需求推动了公司在产品开发上必须非…