Spring Boot基础学习笔记08:Spring Boot整合Redis

Stella981
• 阅读 393

文章目录

零、学习目标

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安装压缩包

2、将Redis安装包解压到任意位置

  • 解压到D:\Program Files\redis目录
    Spring Boot基础学习笔记08:Spring Boot整合Redis

3、给Redis配置环境变量

Spring Boot基础学习笔记08:Spring Boot整合Redis

4、启动Redis服务器

  • 启动命令行窗口,键入redis-server命令
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • The server is now ready to accept connections on port 6379
  • 服务器准备就绪,在端口6379接受连接

5、启动Redis客户端

  • 启动命令行窗口,键入redis-cli命令
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 创建键值对,按键获取值
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 键入exit命令,退出客户端
    Spring Boot基础学习笔记08:Spring Boot整合Redis

(二)安装Redis可视化管理工具

1、下载Redis可视化管理工具

Spring Boot基础学习笔记08:Spring Boot整合Redis

2、安装Redis可视化管理工具

Spring Boot基础学习笔记08:Spring Boot整合Redis
Spring Boot基础学习笔记08:Spring Boot整合Redis
Spring Boot基础学习笔记08:Spring Boot整合Redis

3、启动Redis可视化管理工具

Spring Boot基础学习笔记08:Spring Boot整合Redis

4、Redis可视化工具连接Redis服务

  • 在命令行窗口,启动Redis服务
    Spring Boot基础学习笔记08:Spring Boot整合Redis Spring Boot基础学习笔记08:Spring Boot整合Redis

5、打开Redis可视化工具的控制台

Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 在控制台创建键值对,按键获取值
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 可视化查看刚才创建的键值对(注意city是先前利用Redis客户端创建的)
    Spring Boot基础学习笔记08:Spring Boot整合Redis

6、利用可视化工具操作键值对

  • 创建键值对
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 修改键值对
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 删除键值对
    Spring Boot基础学习笔记08:Spring Boot整合Redis

(三)创建Spring Boot项目RedisDemo

  • 设置项目元数据
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 添加项目依赖
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 设置项目名称与保存位置
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 完成项目初始化工作
    Spring Boot基础学习笔记08:Spring Boot整合Redis

(四)创建实体类

  • 在net.hw.lesson08包里创建bean子包

1、创建地址实体类Address

  • 在net.hw.lesson08.bean包里创建地址实体类Address
    Spring Boot基础学习笔记08:Spring Boot整合Redis

    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
    Spring Boot基础学习笔记08:Spring Boot整合Redis

    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
    Spring Boot基础学习笔记08:Spring Boot整合Redis

    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接口
    Spring Boot基础学习笔记08:Spring Boot整合Redis

    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属性

Spring Boot基础学习笔记08:Spring Boot整合Redis

(七)在测试类里编写测试方法

  • 点开测试类RedisDemoApplicationTests
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 注入PersonRepository实例
    Spring Boot基础学习笔记08:Spring Boot整合Redis

1、创建测试方法testAddPerson()

Spring Boot基础学习笔记08:Spring Boot整合Redis

@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()方法

  • 运行测试方法,查看结果
    Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 在命令行窗口启动redis服务
    Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 运行测试方法,查看结果
    Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 打开Redis可视化工具查看
    Spring Boot基础学习笔记08:Spring Boot整合Redis

2、创建测试方法testFindAll()

Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 运行测试方法,查看结果
    Spring Boot基础学习笔记08:Spring Boot整合Redis

3、测试personRespository的其它方法

Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 创建测试方法testFindById()
    Spring Boot基础学习笔记08:Spring Boot整合Redis
  • 运行测试方法,查看结果
    Spring Boot基础学习笔记08:Spring Boot整合Redis

(八)测试自定义个性化查询方法

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()

Spring Boot基础学习笔记08:Spring Boot整合Redis

  • 运行测试方法,查看结果
    Spring Boot基础学习笔记08:Spring Boot整合Redis

三、课后作业

任务1、在测试类创建测试方法testFindByLastName()

  • 查找姓“张”的记录
    Spring Boot基础学习笔记08:Spring Boot整合Redis

任务2、在测试类创建测试方法testFindPersonByLastNameAndFirstName()

  • 查找lastName为“唐”,firstName为“大明”的记录
    Spring Boot基础学习笔记08:Spring Boot整合Redis

任务3、在测试类创建测试方法testFindByAddress_City()

  • 查找“北京”的记录
    Spring Boot基础学习笔记08:Spring Boot整合Redis

任务4、在测试类创建测试方法testFindByFamilyList_Name()

  • 查找“唐雨涵”
    Spring Boot基础学习笔记08:Spring Boot整合Redis

本文分享 CSDN - howard2005。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
2年前
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解2016年09月02日00:00:36 \牧野(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fme.csdn.net%2Fdcrmg) 阅读数:59593
Stella981 Stella981
2年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这