文章目录
- 零、学习目标
- 一、Redis概述
- 二、使用Spring Boot 整合 Redis
- 三、课后作业
零、学习目标
1、熟悉Redis相关概念
2、掌握使用Spring Boot整合Redis
一、Redis概述
1、Redis简介
- Redis是一个
开源
(BSD许可)的、内存中的数据结构
存储系统,它可以用作数据库
、缓存
和消息中间件
,并提供多种语言的API。 - Redis支持多种类型的数据结构,如 字符串(strings)、散列(hashes)、列表(lists)、集合(sets)、有序集合(sorted sets)与范围查询、bitmaps、 hyperloglogs 和 地理空间(geospatial)、索引半径查询。
- Redis 内置了复制(replication),LUA脚本(Lua scripting),LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动 分区(Cluster)提供高可用性(high availability)。
2、Redis优点
(1)存取速度快
- Redis速度非常快,每秒可执行大约
110000
次的设值操作,或者执行81000
次的读取操作。
(2)数据类型丰富
- Redis支持开发人员常用的大多数数据类型,例如列表、集合、排序集和散列等。
(3)操作具有原子性
- 所有Redis操作都是原子操作,这确保如果两个客户端并发访问,Redis服务器能接收更新后的值。
(4)提供多种功能
- Redis提供了多种功能特性,可用作非关系型数据库、缓存中间件、消息中间件等。
3、Redis官网与在线教程
二、使用Spring Boot 整合 Redis
(一)搭建Redis环境
1、下载Redis安装压缩包
- 下载链接:https://pan.baidu.com/s/1x8AV7w1PE6fR7xS7lwAOWg
- 提取码:j4hq
2、将Redis安装包解压到任意位置
- 解压到
D:\Program Files\redis
目录
3、给Redis配置环境变量
4、启动Redis服务器
- 启动命令行窗口,键入
redis-server
命令 - The server is now ready to accept connections on port
6379
- 服务器准备就绪,在端口
6379
接受连接
5、启动Redis客户端
- 启动命令行窗口,键入
redis-cli
命令 - 创建键值对,按键获取值
- 键入
exit
命令,退出客户端
(二)安装Redis可视化管理工具
1、下载Redis可视化管理工具
- 下载链接:https://pan.baidu.com/s/1EaCKpkGr04QM8QHu3H-G_g
- 提取码:oonx
2、安装Redis可视化管理工具
3、启动Redis可视化管理工具
4、Redis可视化工具连接Redis服务
- 在命令行窗口,启动Redis服务
5、打开Redis可视化工具的控制台
- 在控制台创建键值对,按键获取值
- 可视化查看刚才创建的键值对(注意
city
是先前利用Redis客户端创建的)
6、利用可视化工具操作键值对
- 创建键值对
- 修改键值对
- 删除键值对
(三)创建Spring Boot项目RedisDemo
- 设置项目元数据
- 添加项目依赖
- 设置项目名称与保存位置
- 完成项目初始化工作
(四)创建实体类
- 在net.hw.lesson08包里创建bean子包
1、创建地址实体类Address
在net.hw.lesson08.bean包里创建地址实体类Address
package net.hw.lesson08.bean;
import org.springframework.data.redis.core.index.Indexed;
/**
- 功能:地址实体类
- 作者:华卫
- 日期:2020年08月13日
*/ public class Address {
@Indexed private String country; //国家 @Indexed private String city; //城市 public Address(String country, String city) { this.country = country; this.city = city; } public String getCountry() { return country; } public void setCountry(String country) { this.country = country; } public String getCity() { return city; } public void setCity(String city) { this.city = city; } @Override public String toString() { return "Address{" + "country='" + country + '\'' + ", city='" + city + '\'' + '}'; }
}
注意:索引类
Indexed
不要导入错误 -import org.springframework.data.redis.core.index.Indexed;
2、创建家庭实体类Family
在net.hw.lesson08.bean包里创建家庭实体类Family
package net.hw.lesson08.bean;
import org.springframework.data.redis.core.index.Indexed;
/**
- 功能:家庭实体类
- 作者:华卫
- 日期:2020年08月13日
*/ public class Family {
@Indexed private String type; //成员类型 @Indexed private String name; //成员名 public Family(String type, String name) { this.type = type; this.name = name; } public String getType() { return type; } public void setType(String type) { this.type = type; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "Family{" + "type='" + type + '\'' + ", name='" + name + '\'' + '}'; }
}
3、创建人实体类Person
在net.hw.lesson08.bean包里创建人实体类Family
package net.hw.lesson08.bean;
import org.springframework.data.annotation.Id; import org.springframework.data.redis.core.RedisHash; import org.springframework.data.redis.core.index.Indexed;
import java.util.List;
/**
- 功能:人实体类
- 作者:华卫
- 日期:2020年08月13日
*/ @RedisHash("persons") public class Person {
@Id //主键 private String id; //生成二级索引,方便查询 @Indexed private String firstName; //名 @Indexed private String lastName; //姓 private Address address; //家庭地址 private List<Family> familyList; //家庭成员 public Person(String id, String firstName, String lastName, Address address, List<Family> familyList) { this.id = id; this.firstName = firstName; this.lastName = lastName; this.address = address; this.familyList = familyList; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getFirstName() { return firstName; } public void setFirstName(String firstName) { this.firstName = firstName; } public String getLastName() { return lastName; } public void setLastName(String lastName) { this.lastName = lastName; } public Address getAddress() { return address; } public void setAddress(Address address) { this.address = address; } public List<Family> getFamilyList() { return familyList; } public void setFamilyList(List<Family> familyList) { this.familyList = familyList; } @Override public String toString() { return "Person{" + "id='" + id + '\'' + ", firstName='" + firstName + '\'' + ", lastName='" + lastName + '\'' + ", address=" + address + ", familyList=" + familyList + '}'; }
}
说明:注解
@RedisHash("persons")
,表明在redis数据库中开启一个persons
的内存空间,所有person
操作相关的数据均保存在此空间(redis是内存数据库)。
(五)创建自定义Repository接口
在net.hw.lesson08包里创建repository子包
在net.hw.lesson08.repository包里创建PersonRepository接口
package net.hw.lesson08.repository;
import net.hw.lesson08.bean.Person; import org.springframework.data.repository.CrudRepository;
/**
- 功能:人仓库接口
- 作者:华卫
- 日期:2020年08月13日
*/ public interface PersonRepository extends CrudRepository<Person, String> {
}
(六)在全局配置文件配置Redis属性
(七)在测试类里编写测试方法
- 点开测试类RedisDemoApplicationTests
- 注入PersonRepository实例
1、创建测试方法testAddPerson()
@Test
public void testAddPerson() {
// 添加第一个人
Address address = new Address("中国", "泸州");
Family family1 = new Family("儿子", "张晓刚");
Family family2 = new Family("女儿", "张晓霞");
List<Family> familyList = new ArrayList<Family>();
familyList.add(family1);
familyList.add(family2);
Person person = new Person("1", "无忌", "张", address, familyList);
personRepository.save(person);
// 添加第二个人
address = new Address("中国", "上海");
family1 = new Family("儿子", "李功晨");
family2 = new Family("女儿", "李晓丽");
familyList = new ArrayList<Family>();
familyList.add(family1);
familyList.add(family2);
person = new Person("2", "承鹏", "李", address, familyList);
personRepository.save(person);
// 添加第三个人
address = new Address("中国", "北京");
family1 = new Family("儿子", "唐玉海");
family2 = new Family("女儿", "唐雨涵");
familyList = new ArrayList<Family>();
familyList.add(family1);
familyList.add(family2);
person = new Person("3", "大明", "唐", address, familyList);
personRepository.save(person);
// 添加第四个人
address = new Address("中国", "北京");
family1 = new Family("儿子", "张大明");
family2 = new Family("女儿", "张丽丽");
familyList = new ArrayList<Family>();
familyList.add(family1);
familyList.add(family2);
person = new Person("4", "文勇", "张", address, familyList);
personRepository.save(person);
System.out.println("成功地添加了4条记录~");
}
说明:在这个测试方法里,测试了personRepository的
save()
方法运行测试方法,查看结果
在命令行窗口启动redis服务
运行测试方法,查看结果
打开Redis可视化工具查看
2、创建测试方法testFindAll()
- 运行测试方法,查看结果
3、测试personRespository的其它方法
- 创建测试方法testFindById()
- 运行测试方法,查看结果
(八)测试自定义个性化查询方法
1、在PersonRepository接口定义方法
package net.hw.lesson08.repository;
import net.hw.lesson08.bean.Person;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.repository.CrudRepository;
import java.util.List;
/**
* 功能:人仓库接口
* 作者:华卫
* 日期:2020年08月13日
*/
public interface PersonRepository extends CrudRepository<Person, String> {
//自定义个性化查询,方法名需要符合特定的规范
public List<Person> findByLastName(String lastName);
public Page<Person> findPersonByLastName(String lastName, Pageable pageable);
public List<Person> findPersonByLastNameAndFirstName(String lastName, String firstName);
List<Person> findByAddress_City(String city);
List<Person> findByFamilyList_Name(String name);
}
2、在测试类创建测试方法testFindPersonByLastName()
- 运行测试方法,查看结果
三、课后作业
任务1、在测试类创建测试方法testFindByLastName()
- 查找姓“张”的记录
任务2、在测试类创建测试方法testFindPersonByLastNameAndFirstName()
- 查找lastName为“唐”,firstName为“大明”的记录
任务3、在测试类创建测试方法testFindByAddress_City()
- 查找“北京”的记录
任务4、在测试类创建测试方法testFindByFamilyList_Name()
- 查找“唐雨涵”
本文分享 CSDN - howard2005。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。