Redis速通

一、简介

Redis是一个基于内存的key-value结构数据库。它具有以下优点

1、基于内存存储,读写性能高

2、适合存储热点数据(热点商品,新闻,咨询)

3、企业应用广泛

二、启动

下载解压完redis后,在命令行页面进入到该文件夹,输出以下命令即可启动Redis。

bash 复制代码
redis-server.exe redis.windows.conf

Redis的默认端口为6379,按ctrl+c可以中断(结束)此次Redis的服务。

客户端连接指令:

bash 复制代码
redis-cli.exe

可以在后方跟上一些参数补全连接信息

-h 连接Redis的ip地址

-p 连接Redis的端口号

-a 连接Redis的密码(如果没设置密码就不需要此栏)

设置Redis服务密码,修改redis.windows.conf

bash 复制代码
requirepass 123456

三、Redis中的数据类型

Redis存储的是key-value结构的数据,其中key是字符串类型,value有5种常用的数据类型:

字符串 string

哈希 hash

列表 list

集合 set

有序集合 sorted set / zset

字符串(string):普通字符串,Redis中最简单的数据类型

哈希(hash):也叫散列,类似于Java中的HashMap结构

列表(list):按照插入顺序排序,可以有重复元素,类似于Java中的LinkedList

集合(set):无序集合,没有重复元素,类似于Java中的HashSet

有序集合(sorted set / zset):集合中每个元素关联一个分数(score),根据分数升序排序,没有重复元素

Redis字符串类型常用命令

bash 复制代码
SET key value			设置指定key的值
GET key			获取指定key的值
SETEX key seconds value	设置指定key的值,并将 key 的过期时间设为 seconds 秒
SETNX key value		只有在 key 不存在时设置 key 的值

Redis哈希操作命令

Redis hash 是一个string类型的 field 和 value 的映射表,hash特别适合用于存储对象(例如key为某个人,field1为性别,field2为年龄......),常用命令:

bash 复制代码
HSET key field value 	将哈希表 key 中的字段 field 的值设为 value
HGET key field 	获取存储在哈希表中指定字段的值
HDEL key field		删除存储在哈希表中的指定字段
HKEYS key 		获取哈希表中所有字段
HVALS key 		获取哈希表中所有值

Redis列表操作命令

Redis 列表是简单的字符串列表,按照插入顺序排序,常用命令:

bash 复制代码
LPUSH key value1 [value2] 	将一个或多个值插入到列表头部(左边)
LRANGE key start stop 		获取列表指定范围内的元素
RPOP key 			移除并获取列表最后一个元素(右边)
LLEN key 			获取列表长度
RPUSH key value1 [value2]   将一个或多个值插入到列表尾部(右边)
剩余的右边同理

Redis集合操作命令

Redis set 是string类型的无序集合。集合成员是唯一的,集合中不能出现重复的数据,常用命令:

bash 复制代码
SADD key member1 [member2] 	向集合添加一个或多个成员
SMEMBERS key 		返回集合中的所有成员
SCARD key 			获取集合的成员数
SINTER key1 [key2] 		返回给定所有集合的交集
SUNION key1 [key2] 		返回所有给定集合的并集
SREM key member1 [member2] 	删除集合中一个或多个成员

Redis有序集合操作命令

Redis有序集合是string类型元素的集合,且不允许有重复成员。每个元素都会关联一个double类型的分数。常用命令:

bash 复制代码
ZADD key score1 member1 [score2 member2] 	向有序集合添加一个或多个成员
ZRANGE key start stop [WITHSCORES] 		通过索引区间返回有序集合中指定区间内的成员
ZINCRBY key increment member 			有序集合中对指定成员的分数加上增量 increment
ZREM key member [member ...] 			移除有序集合中的一个或多个成员

通用命令

bash 复制代码
KEYS pattern 		查找所有符合给定模式( pattern)的 key 
EXISTS key 		检查给定 key 是否存在
TYPE key 		返回 key 所储存的值的类型
DEL key 		该命令用于在 key 存在是删除 key

四、java操作Redis

操作步骤: 导入Spring Data Redis 的maven坐标

配置Redis数据源

编写配置类,创建RedisTemplate对象

通过RedisTemplate对象操作Redis

maven依赖

XML 复制代码
    <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>

Redis配置类

java 复制代码
@Configuration
@Slf4j
public class RedisConfiguration {
    @Bean
    public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        log.info("开始创建redis模板类");
        RedisTemplate redisTemplate = new RedisTemplate();
        // 设置Key的序列化器,默认为JdkSerializationRedisSerializer
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        return redisTemplate;
    }
}

配置文件

java 复制代码
spring:
  redis:
    host: localhost
    port: 6379
    database: 10    //Redis默认有从DB0到DB15的16个数据库,这里的数字是选择使用的数据库

SpringDataRedis使用方法

RedisTemplate 针对大量api进行了归类封装,将同一数据类型的操作封装为对应的Operation接口,具体分类如下:

ValueOperations:string数据操作

SetOperations:set类型数据操作

ZSetOperations:zset类型数据操作

HashOperations:hash类型的数据操作

ListOperations:list类型的数据操作

使用示例

java 复制代码
package com.sky.test;

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.*;

import java.util.concurrent.TimeUnit;

@SpringBootTest
public class SpringDataRedisTest {
    @Autowired
    private RedisTemplate redisTemplate;
    @Test
    public void testRedisTemplate(){
        System.out.println(redisTemplate);
        ValueOperations valueOperations = redisTemplate.opsForValue();
        SetOperations setOperations = redisTemplate.opsForSet();
        ZSetOperations zSetOperations = redisTemplate.opsForZSet();
        HashOperations hashOperations = redisTemplate.opsForHash();
        ListOperations listOperations = redisTemplate.opsForList();
    }
    @Test
    public void testString(){
        redisTemplate.opsForValue().set("name","张三");
        System.out.println(redisTemplate.opsForValue().get("name"));
        redisTemplate.opsForValue().set("age",18,1, TimeUnit.MINUTES);
        System.out.println(redisTemplate.opsForValue().get("age"));
        redisTemplate.opsForValue().setIfAbsent("name","张三");
        System.out.println(redisTemplate.opsForValue().get("name"));

    }
}
相关推荐
树在风中摇曳1 小时前
带哨兵位的双向循环链表详解(含 C 代码)+ LeetCode138 深度解析 + 顺序表 vs 链表缓存机制对比(图解 CPU 层级)
c语言·链表·缓存
空空kkk1 小时前
SpringMVC——拦截器
java·数据库·spring·拦截器
J***51682 小时前
MySql中的事务、MySql事务详解、MySql隔离级别
数据库·mysql·adb
SelectDB2 小时前
Apache Doris 中的 Data Trait:性能提速 2 倍的秘密武器
数据库·后端·apache
i***27952 小时前
Spring boot 3.3.1 官方文档 中文
java·数据库·spring boot
TDengine (老段)2 小时前
TDengine 日期函数 DATE 用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
q***65693 小时前
PostgreSQL 中进行数据导入和导出
大数据·数据库·postgresql
一 乐3 小时前
助农平台|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·ecmascript·springboot
NineData3 小时前
保姆级!Oracle→达梦零停机迁移攻略,5 步操作,业务零影响!
数据库·程序员
q***31834 小时前
MySQL---存储过程详解
数据库·mysql