在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
前言:Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合),zset(sorted set:有序集合)。 一、redis去官网https://redis.io/download下载后解压然后点击里面的redis-server.exe(windows平台)即可正常启动 二、在项目中添加redis依赖<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> 三、redis的使用在需要使用redis的地方通过注解注入,比如在Controller中添加 @RestController public class RedisController { @Autowired private StringRedisTemplate stringRedisTemplate;//只支持redis五大类型中的字符串类型 @Autowired private RedisTemplate redisTemplate;//支持redis五大类型中的所有类型 } 四、字符串类型存取(k,v)@RequestMapping("/setString") public Object setString(){ stringRedisTemplate.boundValueOps("s").set("辣椒");//存入 return stringRedisTemplate.boundValueOps("s").get();//读取 } 访问接口查看结果: 五、存取对象(k,object)使用你自己的对象进行存取,我这里使用Person对象 package com.star.pojo; import java.io.Serializable; public class Person implements Serializable { private String name; private int age; private String Add; public Person() { } public Person(String name, int age, String add) { this.name = name; this.age = age; Add = add; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getAdd() { return Add; } public void setAdd(String add) { Add = add; } @Override public String toString() { return "Person{" + "name='" + name + '\'' + ", age=" + age + ", Add='" + Add + '\'' + '}'; } } Person.java @RequestMapping("/setPerson") public Object setPerson(){ Person person = new Person("鱼er", 151, "北京"); redisTemplate.boundValueOps("p").set(person);//存入 return redisTemplate.boundValueOps("p").get();//读取 } 六、List类型(k,list)@RequestMapping("/setList") public List<String> setListRedis(){ List<String> list=new ArrayList<>(); list.add("手头"); list.add("苹果"); list.add("辣椒"); this.redisTemplate.boundValueOps("listk").set(list);//存入 return (List<String>) this.redisTemplate.boundValueOps("listk").get();//读取 } 七、Hash类型(K,k,value)@RequestMapping("/setHash") public List<String> setHash(){ List<String> list=new ArrayList<>(); list.add("大书"); list.add("酸菜"); list.add("鸡蛋"); this.redisTemplate.boundHashOps("thing").put("h",list);//存入 return (List<String>) this.redisTemplate.boundHashOps("thing").get("h");//读取 } 八、然后打开redis desktop manager工具可以看到你存储的数据其安装及连接方式不用多说,基本是个人都会,实在不会可以去这里瞧瞧。 九、如果想要在单元测试中进行存取添加测试依赖,Junit必须4.12以上 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency> 在要进行存取的类上添加注解@RunWith、@SpringBootTest,意思是启动单元测试时启动当前项目的启动类,因为启动类里面的@SpringBootApplication里面包含了包扫描@ComponentScan,不然注入StringRedisTemplate或RedisTemplate时注入失败报空指针,当然也可以在启动类里面返回new StringRedisTemplate或new RedisTemplate并且加注解@Bean的方式处理注入失败问题,这里直接通过加注解的方式处理。 @RunWith(value = SpringJUnit4ClassRunner.class) //RedisApp为启动类名字 @SpringBootTest(classes = {RedisApp.class}) public class RedisAppTest { @Autowired private StringRedisTemplate stringRedisTemplate; @Autowired private RedisTemplate redisTemplate; @Test public void setStringRedis(){ this.stringRedisTemplate.boundValueOps("name2").set("熊大"); System.out.println("ok"); } @Test public void getStringRedis(){ String name = this.stringRedisTemplate.boundValueOps("name2").get(); System.out.println("ok:"+name); } } 在redis desktop manager工具中可以看到存储成功了,在控制台也可以读取 九、实际使用思路@Autowired private RedisTemplate redisTemplate; /** * 首次访问时,如果redis没有数据,就访问数据库,然后把访问到的数据存到redis * 后续访问时,直接查询redis */ @Override public List<Person> findByPersonId(Long id) {// 先查看缓存中有没有 List<Person> list = (List<Person>) redisTemplate.boundValueOps(id).get(); if(list==null){ System.out.println("redis中没有,开始从数据库中获取"); ......... //查询数据库得到List<Person> list =xxxxxx; redisTemplate.boundValueOps(id).set(list);//将从数据库查到的数据添加到redis中以备下次查找 }else{ System.out.println("redis中存在,list是直接从缓存中获取的,没查数据库"); } return list; } 到此这篇关于Springboot/Springcloud项目中集成redis进行存取的文章就介绍到这了,更多相关Springcloud集成redis存取内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论