news 2026/4/5 16:29:47

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/3/31 19:15:51

【大模型可靠性革命】:Open-AutoGLM自主纠错机制带来的3大技术突破

第一章&#xff1a;Open-AutoGLM 自主纠错机制原理Open-AutoGLM 是一种基于生成语言模型的自优化推理框架&#xff0c;其核心在于引入了自主纠错&#xff08;Self-Correction&#xff09;机制&#xff0c;使模型能够在生成输出后主动识别潜在错误并迭代修正。该机制不依赖外部标…

作者头像 李华
网站建设 2026/4/1 21:06:19

从毫秒到毫米:Open-AutoGLM时空对齐机制如何重塑定位精确度(技术深挖)

第一章&#xff1a;从毫秒到毫米——Open-AutoGLM时空对齐的精度革命在自动驾驶与高精地图融合的前沿领域&#xff0c;时间与空间的精确对齐是系统性能的决定性因素。Open-AutoGLM 通过引入神经符号对齐机制&#xff0c;实现了从传统毫秒级时间同步到亚毫米级空间匹配的跨越&am…

作者头像 李华
网站建设 2026/4/5 16:38:02

Open-AutoGLM触控平滑技术深度解析(轨迹预测模型首次公开)

第一章&#xff1a;Open-AutoGLM触控轨迹自然度优化原理在移动交互与手写输入场景中&#xff0c;触控轨迹的自然度直接影响用户体验。Open-AutoGLM 通过融合动态时间规整&#xff08;DTW&#xff09;与贝塞尔平滑插值算法&#xff0c;对原始触控点序列进行重构&#xff0c;有效…

作者头像 李华
网站建设 2026/4/6 4:21:44

Opencv在Visual Studio中的配置使用(python)

1.创建新项目 在这个 Visual Studio 的 Python 项目&#xff08;Python 3.11&#xff09; 中配置 OpenCV&#xff0c;步骤很简单&#xff1a; 配置步骤 打开终端&#xff1a;在 Visual Studio 中&#xff0c;点击「视图」→「终端」&#xff0c;打开项目终端。 2.安装 OpenCV…

作者头像 李华
网站建设 2026/4/3 22:10:04

从自然语言到系统操作,Open-AutoGLM是如何做到零延迟响应的?

第一章&#xff1a;从自然语言到系统操作的零延迟响应机制在现代智能系统中&#xff0c;用户通过自然语言发起指令后&#xff0c;系统需在毫秒级时间内完成语义解析、意图识别与操作执行。实现这一“零延迟”响应的核心在于构建高效的任务流水线&#xff0c;将语言理解模型与操…

作者头像 李华
网站建设 2026/4/5 7:56:51

4、过程工厂数字孪生的需求与流程设计

过程工厂数字孪生的需求与流程设计 1. 需求分析 在构建过程工厂数字孪生时,明确相关需求至关重要。以下是各项需求类别及其衍生需求的占比情况: | 编号 | 需求类别 | 衍生需求占比(%) | | ---- | ---- | ---- | | 1 | 物体的清晰识别 | 71 | | 2 | 物体在空间中的清晰位…

作者头像 李华