SpringDataRedis 基本使用

时间:2022-07-28
本文章向大家介绍SpringDataRedis 基本使用,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1.1 简介

1.1.1 概述

  Spring Data 中有一个成员 Spring Data Redis,他提供了 RedisTemplate 可以在 Spring 应用中更简便的访问 Redis 以及异常处理及序列化,支持发布订阅等操作。

1.1.2 整合 Spring Data Redis

☞ Spring 整合 Spring Data Redis ☞ Spring Boot 整合 Spring Data Redis

1.2 RedisTemplate 常见 API

1.2.1 operation 接口

  RedisTemplate 针对 jedis 客户端中大量 API 进行了归类封装,将同一类型操作封装为 operation 接口  ♞ ValueOperations:简单 string 操作  ♞ ListOperations:针对 list 类型的数据操作  ♞ HashOperations:针对 hash 即 map 类型的数据操作  ♞ SetOperations:set 类型数据操作  ♞ ZSetOperations:zset 类型数据操作

☞ 示例

/**
 * Created with IntelliJ IDEA.
 *
 * @author Demo_Null
 * @date 2020/10/10
 * @description operation 示例
 */
@SpringBootTest
public class RedisTest {
    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void redis() {
        redisTemplate.opsForValue().set("name", "张三");
        Object name = redisTemplate.opsForValue().get("name");
        System.out.println(name);
    }
}

1.2.2 BoundKeyOperations

  RedisTemplate 提供了对 key 的 bound(绑定) 便捷化操作 API,可以通过 bound 封装指定的 key,然后进行一系列的操作而无须显式的再次指定 Key。  ♞ BoundValueOperations:绑定 string 类型的 key  ♞ BoundListOperations:绑定 list 类型的 key  ♞ BoundHashOperations:绑定 hash 即 map 类型的 key  ♞ BoundSetOperations:绑定 set 类型的 key  ♞ BoundZSetOperations:绑定 zset 类型的 key

☞ 示例

/**
 * Created with IntelliJ IDEA.
 *
 * @author Demo_Null
 * @date 2020/10/10
 * @description BoundKeyOperations 示例
 */
@SpringBootTest
public class RedisTest {
    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void redis() {
        Object name = redisTemplate.boundValueOps("name").get();
        System.out.println(name);
    }
}

1.3 数据操作

1.3.1 通用方法

☞ 删除 key
// 删除单个 key,返回布尔值
redisTemplate.delete(K key);

// 删除多个 key,返回删除的个数
redisTemplate.delete(Collection<K> keys);
☞ 判断 key 是否存在
// 返回布尔值
redisTemplate.hasKey(key);
☞ key 有效时间
// 指定有效时间
redisTemplate.expire(key, time, TimeUnit.MINUTES);

// 获取有效时间,返回值单位为秒
redisTemplate.getExpire(key);

1.3.2 操作 string

☞ 添加数据
// 通过 ValueOperations 设置值
ValueOperations ops = redisTemplate.opsForValue();
// 存入数据
ops.set(key, value);	
// 设置过期时间
ops.set(key, value, time, TimeUnit.SECONDS);	

// 通过 BoundValueOperations 设置值
BoundValueOperations key = redisTemplate.boundValueOps(key);
key.set(value);
key.set(value, time, TimeUnit.SECONDS);
☞ 获取数据
// 通过 ValueOperations 获取值
redisTemplate.opsForValue().get(key);

// 通过 BoundValueOperations 获取值
redisTemplate.boundValueOps(key).get();

1.3.3 操作 list

☞ 添加数据
// 通过 ValueOperations 设置值
ListOperations opsList = redisTemplate.opsForList();
opsList.leftPush(listKey, listLeftValue);
opsList.rightPush(listKey, listRightValue);
// 存入集合
opsList.rightPushAll(list);	
opsList.leftPushAll(list);

// BoundValueOperations 操作类似
☞ 获取数据
// 获取集合中的数据
redisTemplate.boundListOps(listKey).range(startIndex, endindex); 

// 根据索引获取数据
redisTemplate.boundListOps(listKey).index(index);

// 集合长度
redisTemplate.boundListOps(listKey).size();
☞ 删除数据
// 从左侧弹出一个元素并返回
redisTemplate.boundListOps(listKey).leftPop();  

// 从右侧弹出一个元素并返回
redisTemplate.boundListOps(listKey).rightPop(); 

// 移出 N 个值为 value 的元素
redisTemplate.boundListOps(listKey).remove(long, value); 
☞ 修改数据
// 根据索引修改数据
redisTemplate.boundListOps(listKey).set(index, listLeftValue);

1.3.4 hash

☞ 添加数据
// 通过 BoundValueOperations 设置值
BoundHashOperations hashKey = redisTemplate.boundHashOps(HashKey);
hashKey.put(key, Vaue);
// 添加一个集合
hashKey.putAll(hashMap); 

// 通过 ValueOperations 设置值
HashOperations hashOps = redisTemplate.opsForHash();
hashOps.put(HashKey, key, Vaue);
☞ 获取数据
// 获取所有小 key
redisTemplate.boundHashOps(HashKey).keys();

// 根据小 key 获取值
redisTemplate.boundHashOps(HashKey)get(key);

// 获取所有键值对集合
redisTemplate.boundHashOps(HashKey).entries();
☞ 删除数据
// 判断 hash 中是否存在小 key
redisTemplate.boundHashOps(HashKey).hasKey(key);

// 根据小 key 删除值
redisTemplate.boundHashOps(HashKey).delete(key);

1.3.5 set

☞ 添加数据
// 通过 BoundValueOperations 设置值
redisTemplate.boundSetOps(setKey).add(setValue1, setValue2, setValue3);

// 通过 ValueOperations 设置值
redisTemplate.opsForSet().add(setKey, SetValue1, setValue2, setValue");
☞ 获取数据
// 获取所有值
redisTemplate.boundSetOps(setKey).members();

// 获取 set 的长度
redisTemplate.boundSetOps(setKey).size();
☞ 删除数据
// 判断 set 中是否存在改值
redisTemplate.boundSetOps(setKey).isMember(setValue);

// 移出指定的值
redisTemplate.boundSetOps(setKey).remove(setValue);

1.3.6 zset

☞ 添加数据
// 通过 BoundValueOperations 设置值
redisTemplate.boundZSetOps(zSetKey).add(zSetVaule, score);

// 通过 ValueOperations 设置值
redisTemplate.opsForZSet().add(zSetKey, zSetVaule, score);
☞ 获取数据
// 获取元素集合, 按照排名先后(从小到大)
redisTemplate.boundZSetOps(zSetKey).range(key, startIndex, endIndex);

// 获取指定值的分数(权重)
redisTemplate.boundZSetOps(zSetKey).score(zSetVaule);

// 获取 zset 长度
redisTemplate.boundZSetOps(zSetKey).size();
☞ 修改分数
// 修改指定元素的分数
redisTemplate.boundZSetOps(zSetKey).incrementScore(zSetVaule, score);
☞ 删除数据
// 删除指定元素
redisTemplate.boundZSetOps(zSetKey).remove(zSetVaule);

// 删除指定索引范围的元素
redisTemplate.boundZSetOps(zSetKey).removeRange(strat, end);

// 删除指定分数范围的元素
redisTemplate.boundZSetOps(zSetKey).removeRangeByScorssse(strat, end);