redis 中 redisTemplate 的所有操作与函数详解

 更新时间:2025年12月23日 10:47:55   作者:Billow_lamb  
本文介绍了RedisCache的多种操作,包括Key、通用、String、Hash、List、Set、ZSet、事务、管道、发布订阅和Lua脚本执行等,感兴趣的朋友跟随小编一起看看吧

版本

 <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-redis</artifactId>
      <version>2.7.3</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-dependencies</artifactId>
        <version>2.6.13</version>
      </dependency>

RedisCache 文件

@Component
public class RedisCache
{
    @Autowired
    public RedisTemplate redisTemplate;
}

一、基础操作

1.1 Key 相关操作

// 删除 key
redisTemplate.delete("key");
// 删除多个 key
redisTemplate.delete(Arrays.asList("key1", "key2"));
// 判断 key 是否存在
Boolean exists = redisTemplate.hasKey("key");
// 设置过期时间(秒)
redisTemplate.expire("key", 60, TimeUnit.SECONDS);
// 获取过期时间
Long expireTime = redisTemplate.getExpire("key");
// 移除过期时间,永久保存
redisTemplate.persist("key");
// 获取所有匹配的 key
Set<String> keys = redisTemplate.keys("pattern*");

1.2 通用操作

// 获取 key 的类型
DataType type = redisTemplate.type("key");
// 随机获取一个 key
String randomKey = redisTemplate.randomKey();
// 重命名 key
redisTemplate.rename("oldKey", "newKey");
// 移动 key 到指定数据库
redisTemplate.move("key", 1);

二、String 类型操作

2.1 基本操作

// 设置值
redisTemplate.opsForValue().set("key", "value");
// 设置值并设置过期时间
redisTemplate.opsForValue().set("key", "value", 10, TimeUnit.MINUTES);
// 获取值
String value = (String) redisTemplate.opsForValue().get("key");
// 设置新值并返回旧值
Object oldValue = redisTemplate.opsForValue().getAndSet("key", "newValue");
// 批量设置
Map<String, String> map = new HashMap<>();
redisTemplate.opsForValue().multiSet(map);
// 批量获取
List<Object> values = redisTemplate.opsForValue().multiGet(Arrays.asList("key1", "key2"));

2.2 数值操作

// 递增
Long incremented = redisTemplate.opsForValue().increment("counter", 1);
// 递减
Long decremented = redisTemplate.opsForValue().decrement("counter", 1);
// 浮点数增加
Double doubleValue = redisTemplate.opsForValue().increment("doubleKey", 1.5);

三、Hash 类型操作

// 设置单个 field
redisTemplate.opsForHash().put("hashKey", "field", "value");
// 获取单个 field
Object fieldValue = redisTemplate.opsForHash().get("hashKey", "field");
// 设置多个 field
Map<String, String> hashMap = new HashMap<>();
redisTemplate.opsForHash().putAll("hashKey", hashMap);
// 获取所有 field
Map<Object, Object> allEntries = redisTemplate.opsForHash().entries("hashKey");
// 删除 field
redisTemplate.opsForHash().delete("hashKey", "field1", "field2");
// 判断 field 是否存在
Boolean hasField = redisTemplate.opsForHash().hasKey("hashKey", "field");
// 获取所有 keys(fields)
Set<Object> hashKeys = redisTemplate.opsForHash().keys("hashKey");
// 获取所有 values
List<Object> hashValues = redisTemplate.opsForHash().values("hashKey");
// 获取大小
Long size = redisTemplate.opsForHash().size("hashKey");

四、List 类型操作

// 左侧插入
redisTemplate.opsForList().leftPush("listKey", "value");
// 右侧插入
redisTemplate.opsForList().rightPush("listKey", "value");
// 批量插入
redisTemplate.opsForList().rightPushAll("listKey", "v1", "v2", "v3");
// 左侧弹出
Object leftValue = redisTemplate.opsForList().leftPop("listKey");
// 右侧弹出
Object rightValue = redisTemplate.opsForList().rightPop("listKey");
// 获取列表长度
Long listSize = redisTemplate.opsForList().size("listKey");
// 获取指定范围元素
List<Object> range = redisTemplate.opsForList().range("listKey", 0, -1);
// 根据索引获取元素
Object element = redisTemplate.opsForList().index("listKey", 1);
// 设置指定位置的值
redisTemplate.opsForList().set("listKey", 0, "newValue");
// 删除指定值的元素
redisTemplate.opsForList().remove("listKey", 1, "value");

五、Set 类型操作

// 添加元素
redisTemplate.opsForSet().add("setKey", "value1", "value2");
// 获取所有元素
Set<Object> members = redisTemplate.opsForSet().members("setKey");
// 判断是否成员
Boolean isMember = redisTemplate.opsForSet().isMember("setKey", "value");
// 删除元素
Long removed = redisTemplate.opsForSet().remove("setKey", "value");
// 获取大小
Long setSize = redisTemplate.opsForSet().size("setKey");
// 求交集
Set<Object> intersect = redisTemplate.opsForSet().intersect("set1", "set2");
// 求并集
Set<Object> union = redisTemplate.opsForSet().union("set1", "set2");
// 求差集
Set<Object> difference = redisTemplate.opsForSet().difference("set1", "set2");

六、ZSet(有序集合)操作

// 添加元素(带分数)
redisTemplate.opsForZSet().add("zsetKey", "value", 100);
// 获取分数
Double score = redisTemplate.opsForZSet().score("zsetKey", "value");
// 增加分数
Double newScore = redisTemplate.opsForZSet().incrementScore("zsetKey", "value", 10);
// 按排名范围获取
Set<Object> rangeByRank = redisTemplate.opsForZSet().range("zsetKey", 0, -1);
// 按分数范围获取
Set<Object> rangeByScore = redisTemplate.opsForZSet().rangeByScore("zsetKey", 0, 100);
// 获取排名(从低到高)
Long rank = redisTemplate.opsForZSet().rank("zsetKey", "value");
// 获取排名(从高到低)
Long reverseRank = redisTemplate.opsForZSet().reverseRank("zsetKey", "value");
// 删除元素
redisTemplate.opsForZSet().remove("zsetKey", "value");
// 按排名范围删除
redisTemplate.opsForZSet().removeRange("zsetKey", 0, 5);
// 按分数范围删除
redisTemplate.opsForZSet().removeRangeByScore("zsetKey", 0, 50);

七、事务操作

// 开启事务支持
redisTemplate.setEnableTransactionSupport(true);
// 执行事务
List<Object> results = redisTemplate.execute(new SessionCallback<List<Object>>() {
    @Override
    public List<Object> execute(RedisOperations operations) throws DataAccessException {
        operations.multi();  // 开始事务
        operations.opsForValue().set("key1", "value1");
        operations.opsForValue().set("key2", "value2");
        return operations.exec();  // 执行事务
    }
});

八、管道操作

// 使用管道批量操作
List<Object> results = redisTemplate.executePipelined(new RedisCallback<Object>() {
    @Override
    public Object doInRedis(RedisConnection connection) throws DataAccessException {
        connection.openPipeline();
        connection.set("key1".getBytes(), "value1".getBytes());
        connection.set("key2".getBytes(), "value2".getBytes());
        return null;
    }
});

九、发布订阅

// 发送消息到频道
redisTemplate.convertAndSend("channelName", "message content");
// 接收消息需要配置 MessageListener(通常通过配置类实现)

十、Lua脚本执行

// 执行 Lua 脚本
DefaultRedisScript<Long> script = new DefaultRedisScript<>();
script.setScriptText("return redis.call('get', KEYS[1])");
script.setResultType(Long.class);
Long result = redisTemplate.execute(script, Arrays.asList("key"));

到此这篇关于redis 中 redisTemplate 的所有操作与函数详解的文章就介绍到这了,更多相关redis redisTemplate函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用redis-plus-plus库连接redis的实现方法

    使用redis-plus-plus库连接redis的实现方法

    本文主要介绍了使用redis-plus-plus库连接redis的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-02-02
  • redis启动失败问题之完美解决方案

    redis启动失败问题之完美解决方案

    这篇文章主要介绍了redis启动失败问题之完美解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Redis的数据类型和内部编码详解

    Redis的数据类型和内部编码详解

    Redis是通过Key-Value的形式来组织数据的,而Key的类型都是String,而Value的类型可以有很多,在Redis中最通用的数据类型大致有这几种:String、List、Set、Hash、Sorted Set,下面通过本文介绍Redis数据类型和内部编码,感兴趣的朋友一起看看吧
    2024-04-04
  • Redis事务处理的实现示例

    Redis事务处理的实现示例

    这篇文章主要介绍了Redis事务处理的实现示例,包括事务的原理、相关命令,如MULTI、EXEC、WATCH等、CAS乐观锁实现方式以及事务执行步骤,感兴趣的可以了解一下
    2025-10-10
  • Redis过期数据的删除策略详解

    Redis过期数据的删除策略详解

    Redis 是一个kv型数据库,我们所有的数据都是存放在内存中的,但是内存是有大小限制的,不可能无限制的增量,这篇文章主要介绍了Redis过期数据的删除策略,需要的朋友可以参考下
    2023-08-08
  • Redis实现订单过期删除的方法步骤

    Redis实现订单过期删除的方法步骤

    本文主要介绍了Redis实现订单过期删除的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • Redis的持久化详解

    Redis的持久化详解

    Redis是一个基于内存的数据库,它的数据是存放在内存中,内存有个问题就是关闭服务或者断电会丢失,Redis的数据也支持写到硬盘中,这个过程就叫做持久化,文中有详细的图介绍,需要的朋友可以参考下
    2023-06-06
  • Redis Desktop Manager(Redis可视化工具)安装及使用图文教程

    Redis Desktop Manager(Redis可视化工具)安装及使用图文教程

    这篇文章主要介绍了Redis Desktop Manager(Redis可视化工具)安装及使用图文教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-04-04
  • 阿里云服务器安装配置redis的方法并且加入到开机启动(推荐)

    阿里云服务器安装配置redis的方法并且加入到开机启动(推荐)

    这篇文章主要介绍了阿里云服务器安装配置redis并且加入到开机启动,需要的朋友可以参考下
    2017-12-12
  • Redis在docker上安装、启动、停止和删除操作的完整指南

    Redis在docker上安装、启动、停止和删除操作的完整指南

    Redis是一个开源的键值对存储系统,常用于缓存、消息队列等场景,Docker 是一个轻量级的容器化平台,可以轻松地部署和运行各种应用,本文将详细介绍如何在 Docker 上安装、启动、停止和删除 Redis,需要的朋友可以参考下
    2025-08-08

最新评论