news 2026/6/10 7:13:16

Spring Boot + Redis 注解极简教程:5分钟搞定CRUD操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Spring Boot + Redis 注解极简教程:5分钟搞定CRUD操作

Spring Boot 整合 Redis 注解实现简单 CRUD

可以关注:小坏说Java 公众号

零基础全栈开发Java微服务版本实战-后端-前端-运维-实战企业级三个实战项目

一、项目搭建

零基础全栈开发Java微服务版本实战-后端-前端-运维-实战企业级三个实战项目

1.1 添加依赖

<!-- pom.xml --><dependencies><!-- Spring Boot Web --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- Spring Boot Redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!-- Lombok --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency></dependencies>

1.2 配置文件

# application.ymlspring:redis:host:localhostport:6379database:0server:port:8080

二、实体类

零基础全栈开发Java微服务版本实战-后端-前端-运维-实战企业级三个实战项目

packagecom.example.entity;importlombok.Data;importorg.springframework.data.annotation.Id;importorg.springframework.data.redis.core.RedisHash;importorg.springframework.data.redis.core.index.Indexed;importjava.io.Serializable;/** * @RedisHash: 声明实体类,value指定Redis中的key前缀 * 存储格式: user:{id} */@Data@RedisHash("user")publicclassUserimplementsSerializable{@IdprivateLongid;// 主键@IndexedprivateStringusername;// 创建索引,可以按username查询privateStringemail;privateIntegerage;}

三、Repository 接口

packagecom.example.repository;importcom.example.entity.User;importorg.springframework.data.repository.CrudRepository;importorg.springframework.stereotype.Repository;importjava.util.List;importjava.util.Optional;/** * CrudRepository 提供基本的CRUD方法 * 可以根据方法名自动生成查询 */@RepositorypublicinterfaceUserRepositoryextendsCrudRepository<User,Long>{// 根据用户名查询(精确匹配)List<User>findByUsername(Stringusername);// 根据邮箱查询Optional<User>findByEmail(Stringemail);// 根据年龄范围查询List<User>findByAgeBetween(IntegerminAge,IntegermaxAge);// 删除指定用户名的用户LongdeleteByUsername(Stringusername);}

四、Service 层

packagecom.example.service;importcom.example.entity.User;importcom.example.repository.UserRepository;importlombok.extern.slf4j.Slf4j;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.cache.annotation.*;importorg.springframework.stereotype.Service;importjava.util.List;importjava.util.Optional;@Slf4j@Service@CacheConfig(cacheNames="user")// 类级别缓存配置publicclassUserService{@AutowiredprivateUserRepositoryuserRepository;/** * @Cacheable: 查询缓存 * 1. 先查缓存,有则直接返回 * 2. 无则执行方法,将结果存入缓存 */@Cacheable(key="#id")publicUserfindById(Longid){log.info("查询数据库,用户ID: {}",id);returnuserRepository.findById(id).orElse(null);}/** * 查询所有用户 */publicList<User>findAll(){return(List<User>)userRepository.findAll();}/** * 根据用户名查询 */publicList<User>findByUsername(Stringusername){returnuserRepository.findByUsername(username);}/** * @CachePut: 更新缓存 * 每次都会执行方法,并将结果更新到缓存 */@CachePut(key="#user.id")publicUsersave(Useruser){log.info("保存用户: {}",user.getUsername());returnuserRepository.save(user);}/** * @CacheEvict: 删除缓存 * 方法执行后删除指定key的缓存 */@CacheEvict(key="#id")publicvoiddeleteById(Longid){log.info("删除用户,ID: {}",id);userRepository.deleteById(id);}/** * 更新用户 */@Caching(put=@CachePut(key="#user.id"),evict=@CacheEvict(key="'list'")// 清除列表缓存)publicUserupdate(Useruser){log.info("更新用户: {}",user.getId());returnuserRepository.save(user);}/** * 缓存用户列表 */@Cacheable(key="'list'")publicList<User>findAllWithCache(){log.info("查询所有用户(带缓存)");return(List<User>)userRepository.findAll();}}

五、Controller 层

零基础全栈开发Java微服务版本实战-后端-前端-运维-实战企业级三个实战项目

packagecom.example.controller;importcom.example.entity.User;importcom.example.service.UserService;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.web.bind.annotation.*;importjava.util.List;@RestController@RequestMapping("/api/users")publicclassUserController{@AutowiredprivateUserServiceuserService;// 新增用户@PostMappingpublicUsercreateUser(@RequestBodyUseruser){returnuserService.save(user);}// 根据ID查询用户@GetMapping("/{id}")publicUsergetUserById(@PathVariableLongid){returnuserService.findById(id);}// 查询所有用户@GetMappingpublicList<User>getAllUsers(){returnuserService.findAllWithCache();}// 根据用户名查询@GetMapping("/search")publicList<User>getUserByUsername(@RequestParamStringusername){returnuserService.findByUsername(username);}// 更新用户@PutMapping("/{id}")publicUserupdateUser(@PathVariableLongid,@RequestBodyUseruser){user.setId(id);returnuserService.update(user);}// 删除用户@DeleteMapping("/{id}")publicStringdeleteUser(@PathVariableLongid){userService.deleteById(id);return"删除成功";}}

六、主启动类

零基础全栈开发Java微服务版本实战-后端-前端-运维-实战企业级三个实战项目

packagecom.example;importorg.springframework.boot.SpringApplication;importorg.springframework.boot.autoconfigure.SpringBootApplication;importorg.springframework.cache.annotation.EnableCaching;@SpringBootApplication@EnableCaching// 开启缓存支持publicclassApplication{publicstaticvoidmain(String[]args){SpringApplication.run(Application.class,args);}}

七、测试示例

7.1 使用 Postman 测试

1. 新增用户
POST http://localhost:8080/api/users Content-Type: application/json { "username": "张三", "email": "zhangsan@example.com", "age": 25 }
2. 查询用户
GET http://localhost:8080/api/users/1
3. 查询所有用户
GET http://localhost:8080/api/users
4. 更新用户
PUT http://localhost:8080/api/users/1 Content-Type: application/json { "username": "张三", "email": "zhangsan_new@example.com", "age": 26 }
5. 删除用户
DELETE http://localhost:8080/api/users/1

八、注解总结

注解作用示例
@RedisHash实体类映射到Redis Hash@RedisHash("user")
@Id标记主键字段@Id private Long id;
@Indexed创建二级索引,支持字段查询@Indexed private String username;
@EnableCaching启用缓存(主类上)@EnableCaching
@Cacheable方法结果缓存@Cacheable(key = "#id")
@CachePut更新缓存@CachePut(key = "#user.id")
@CacheEvict删除缓存@CacheEvict(key = "#id")
@Caching组合多个缓存操作见上面Service中的update方法

九、运行效果

零基础全栈开发Java微服务版本实战-后端-前端-运维-实战企业级三个实战项目

  1. 第一次查询用户(1):控制台打印日志"查询数据库"
  2. 第二次查询用户(1):直接从缓存返回,不打印日志
  3. 更新用户(1):更新数据库,并更新缓存
  4. 删除用户(1):删除数据库记录,并清除缓存

十、注意事项

  1. 实体类必须实现Serializable接口
  2. 缓存注解的方法必须是public
  3. 同一个类内部调用缓存注解的方法不会生效
  4. Redis 需要提前安装并启动

这个示例包含了最基本的 Redis 注解 CRUD 操作,可以直接运行使用。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 13:39:16

FaceFusion用户反馈精选:这些功能最受期待

FaceFusion用户反馈精选&#xff1a;这些功能最受期待 在短视频、虚拟人和AI内容创作爆发的今天&#xff0c;人脸编辑技术早已不再是实验室里的概念。从一键“变老”滤镜到直播间的实时换脸&#xff0c;背后都离不开像 FaceFusion 这样的开源项目推动。它不仅让开发者能快速集成…

作者头像 李华
网站建设 2026/6/9 16:22:17

Open-AutoGLM内存占用暴增?掌握这3种优化手段,显存直降80%!

第一章&#xff1a;Open-AutoGLM内存占用暴增的根源剖析在部署 Open-AutoGLM 模型过程中&#xff0c;部分用户反馈其推理服务在持续运行后出现内存占用急剧上升的现象&#xff0c;甚至导致系统 OOM&#xff08;Out-of-Memory&#xff09;终止进程。该问题并非由单一因素引发&am…

作者头像 李华
网站建设 2026/6/10 13:02:16

揭秘Open-AutoGLM工作流:如何实现指令到操作的毫秒级转化

第一章&#xff1a;Open-AutoGLM工作流核心架构解析Open-AutoGLM 是一个面向生成式语言模型自动化推理与任务编排的开源框架&#xff0c;其核心架构设计聚焦于模块解耦、流程可扩展性与执行效率优化。系统通过统一的任务调度层协调多阶段处理单元&#xff0c;实现从输入解析、上…

作者头像 李华
网站建设 2026/6/9 18:21:59

17、过程工厂数字孪生的实现与优化

过程工厂数字孪生的实现与优化 1. 实际工作流程概述 过程工厂数字孪生的实现涉及一个复杂的流程链,包含几十个工作步骤,且至少受四个独立主体的影响。因此,需要对这个复杂的过程进行精确的监控、跟踪和控制。在采用合适的工作流软件实施之前,必须明确扫描、分割、分类以及…

作者头像 李华
网站建设 2026/6/10 7:25:03

4、5G驱动:“无处不在的连接世界”

5G驱动:“无处不在的连接世界” 毫米波通信的潜力与挑战 毫米波通信拥有9GHz的非授权频谱,这一频谱量极为可观,相比全球所有蜂窝技术分配的频谱(不足780MHz)有巨大优势。它能提供超宽带无线通道,无缝连接有线和无线网络,彻底改变移动通信。 毫米波通信的优势还包括:…

作者头像 李华
网站建设 2026/6/10 12:56:00

23、数字孪生:过程工厂的发展与挑战

数字孪生:过程工厂的发展与挑战 数字孪生解决方案的相关发展 扫描过程的进展 扫描过程在数字孪生解决方案中至关重要,尽管点云生成通常由外部合作伙伴完成,但它对数据的质量、范围和整个流程的性能有重要影响。近年来,对记录系统的要求相对稳定,独立的地面激光扫描仪能…

作者头像 李华