写在前面 博客是我平时做项目和学习的过程,很基础,但是每一篇我很认真在写,力求让读者,读的清楚,看的明白。 不是大佬,但努力成为,如果您也对Java、算法感兴趣,可以相互关注,一起成长,相信滴水穿石的力量 为什么使用缓存 Redis缓存 在github上Redis已经停更了,在网上参考了一个链接 在解压好的文件夹下输入cmd命令 新建好项目的童鞋可以自动跳过 1.pom.xml文件引入坐标 2.在appliaction.properties配置redis数据库连接信息 3.在SpringbootdemoApplicationTests中测试操作Redis 对于Redis的五大常用数据类型都提供了方法 String(字符串)、List(列表)、Set(集合)、Hash(散列)、ZSet(有序集合) 使用RedisDesktopManager可视化工具查看结果 下面就用RedisTemplate实现从MySQL数据库取出数据放到Redis缓存 建表的sql脚本 application.properties配置文件 User类 UserMapper类 自定义序列化类,将存储在Redis的对象序列化为json格式,不会产生乱码 IUserService UserService实现类 打开浏览器输入下方url 整体来说,操作Redis是两个类,RedisTemplate类和StringTemplate类,为父子关系,提供的方法正好对应操作Redis数据类型的指令,所以要把数据类型及常用的指令练熟。 在实际业务中Redis的应用不止这些,继续探索吧
大家好,我是Think-Coder,比较通俗的昵称,寓意是做一个有思考的程序猿,现在的状态是边做项目边学习;文章目录
一、基本概况
二、搭建Redis环境
1.下载Redis
链接:https://pan.baidu.com/s/1q8Xg4aG1YEGepl6kc6uP-Q 提取码:os8a2.设置Redis开机自启
window下安装Redis服务redis-server --service-install redis.windows.conf
检查安装是否成功
搜索服务
点击设置为开机自启三、新建SpringBoot项目
添加web依赖
选择数据库依赖
选择项目位置,点击finish
四、使用StringRedisTemplate操作Redis
<!--redis依赖包--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
#redis配置 #Redis服务器地址 spring.redis.host=127.0.0.1 #Redis服务器连接端口 spring.redis.port=6379 #Redis数据库索引(默认为0) spring.redis.database=0
@SpringBootTest class SpringbootdemoApplicationTests { @Autowired StringRedisTemplate stringRedisTemplate; //操作key-value都是字符串,最常用 @Test public void test01(){ //字符串操作 stringRedisTemplate.opsForValue().append("msg","coder"); //列表操作 stringRedisTemplate.opsForList().leftPush("mylist","1"); stringRedisTemplate.opsForList().leftPush("mylist","2"); } }
stringRedisTemplate.opsForValue();[String(字符串)]
stringRedisTemplate.opsForList();[List(列表)]
stringRedisTemplate.opsForSet();[Set(集合)]
stringRedisTemplate.opsForHash();[Hash(散列)]
stringRedisTemplate.opsForZSet();[ZSet(有序集合)]
StringTemplate类中方法存取的key-value值是String类型,RedisTemplate中key-value值是Object类型,RedisTemplate是StringTemplate父类五、使用RedisTemplate操作Redis
1.项目目录结构
2.建立与数据库相关的类
CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(32) NOT NULL COMMENT '用户名称', `birthday` datetime DEFAULT NULL COMMENT '生日', `sex` char(1) DEFAULT NULL COMMENT '性别', `address` varchar(256) DEFAULT NULL COMMENT '地址', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=49 DEFAULT CHARSET=utf8;
#MySQL的配置 spring.datasource.url= jdbc:mysql://localhost:3306/selfproj?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver #设置访问端口号 server.port = 8099 #redis配置 #Redis服务器地址 spring.redis.host=127.0.0.1 #Redis服务器连接端口 spring.redis.port=6379 #Redis数据库索引(默认为0) spring.redis.database=0
package com.thinkcoder.bean; import java.io.Serializable; import java.util.Date; /** * @ClassName User * @Author Think-Coder * @Data 2020/5/27 10:35 * @Version 1.0 */ public class User implements Serializable { private Integer id; private String username; private Date birthday; private String sex; private String address; //getter和setter方法 public Integer getId() {return id;} public void setId(Integer id) {this.id = id;} public String getUsername() {return username;} public void setUsername(String username) {this.username = username;} public Date getBirthday() {return birthday;} public void setBirthday(Date birthday) {this.birthday = birthday;} public String getSex() {return sex;} public void setSex(String sex) {this.sex = sex;} public String getAddress() {return address;} public void setAddress(String address) {this.address = address;} //重写toString方法 @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + ''' + ", birthday=" + birthday + ", sex='" + sex + ''' + ", address='" + address + ''' + '}'; } }
@Mapper public interface UserMapper { @Select("SELECT * FROM user WHERE id = #{id}") User findById(int id); }
3.MyRedisConfig
@Configuration @EnableAutoConfiguration public class MyRedisConfig { @Bean public RedisTemplate<Object, User> redisTemplate(RedisConnectionFactory redisConnectionFactory){ RedisTemplate<Object, User> template = new RedisTemplate<>(); template.setConnectionFactory(redisConnectionFactory); Jackson2JsonRedisSerializer<User> ser = new Jackson2JsonRedisSerializer<>(User.class); template.setDefaultSerializer(ser); return template; } }
4.工具类RedisUtil类
//工具类中使用Autowired注解需要加上Compoent @Component public class RedisUtil { @Autowired RedisTemplate redisTemplate; //key-value是对象的 //判断是否存在key public boolean hasKey(String key){ return redisTemplate.hasKey(key); } //从redis中获取值 public Object get(String key){ return redisTemplate.opsForValue().get(key); } //向redis插入值 public boolean set(final String key,Object value){ boolean result = false; try{ redisTemplate.opsForValue().set(key,value); result = true; }catch (Exception e){ e.printStackTrace(); } return result; } }
5.sevice包代码
@Service public interface IUserService { //根据id查用户信息 User findById(int id); }
@Service public class UserServiceImpl implements IUserService { User user; @Autowired UserMapper userMapper; @Autowired private RedisUtil redisUtil; @Override public User findById(int id) { String key = "user"+id; if(redisUtil.hasKey(key)) { user = (User)redisUtil.get(key); System.out.println("查询的是缓存"); }else{ user = userMapper.findById(id); System.out.println("查询的是数据库"); System.out.println(redisUtil.set(key,user) ? "插入成功" : "插入失败"); } return user; } }
6.UserController类
@RestController public class UserController { @Autowired IUserService userService; @GetMapping("/user/{id}") public User findById(@PathVariable("id") Integer id){ User user = userService.findById(id); return user; } }
7.测试
查看控制台输出
Redis Desktop Manager显示结果
六、总结
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算