华仔自驾游 發表於 2025-12-23 10:47:55

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

<div id="navCategory"><h5 class="catalogue">目录</h5><ul class="first_class_ul"><li><a href="#_label0">一、基础操作</a></li><ul class="second_class_ul"><li><a href="#_lab2_0_0">1.1 Key 相关操作</a></li><li><a href="#_lab2_0_1">1.2 通用操作</a></li></ul><li><a href="#_label1">二、String 类型操作</a></li><ul class="second_class_ul"><li><a href="#_lab2_1_2">2.1 基本操作</a></li><li><a href="#_lab2_1_3">2.2 数值操作</a></li></ul><li><a href="#_label2">三、Hash 类型操作</a></li><ul class="second_class_ul"></ul><li><a href="#_label3">四、List 类型操作</a></li><ul class="second_class_ul"></ul><li><a href="#_label4">五、Set 类型操作</a></li><ul class="second_class_ul"></ul><li><a href="#_label5">六、ZSet(有序集合)操作</a></li><ul class="second_class_ul"></ul><li><a href="#_label6">七、事务操作</a></li><ul class="second_class_ul"></ul><li><a href="#_label7">八、管道操作</a></li><ul class="second_class_ul"></ul><li><a href="#_label8">九、发布订阅</a></li><ul class="second_class_ul"></ul><li><a href="#_label9">十、Lua脚本执行</a></li><ul class="second_class_ul"></ul></ul></div><p>版本</p>
<div class="jb51code"><pre class="brush:plain;"> &lt;dependency&gt;
      &lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
      &lt;artifactId&gt;spring-boot-starter-data-redis&lt;/artifactId&gt;
      &lt;version&gt;2.7.3&lt;/version&gt;
    &lt;/dependency&gt;
    &lt;dependency&gt;
      &lt;groupId&gt;org.springframework.boot&lt;/groupId&gt;
      &lt;artifactId&gt;spring-boot-dependencies&lt;/artifactId&gt;
      &lt;version&gt;2.6.13&lt;/version&gt;
      &lt;/dependency&gt;</pre></div>
<p>RedisCache 文件</p>
<div class="jb51code"><pre class="brush:java;">@Component
public class RedisCache
{
    @Autowired
    public RedisTemplate redisTemplate;
}</pre></div>
<p class="maodian"><a name="_label0"></a></p><h2>一、基础操作</h2>
<p class="maodian"><a name="_lab2_0_0"></a></p><h3>1.1 Key 相关操作</h3>
<div class="jb51code"><pre class="brush:java;">// 删除 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&lt;String&gt; keys = redisTemplate.keys("pattern*");</pre></div>
<p class="maodian"><a name="_lab2_0_1"></a></p><h3>1.2 通用操作</h3>
<div class="jb51code"><pre class="brush:java;">// 获取 key 的类型
DataType type = redisTemplate.type("key");
// 随机获取一个 key
String randomKey = redisTemplate.randomKey();
// 重命名 key
redisTemplate.rename("oldKey", "newKey");
// 移动 key 到指定数据库
redisTemplate.move("key", 1);</pre></div>
<p class="maodian"><a name="_label1"></a></p><h2>二、String 类型操作</h2>
<p class="maodian"><a name="_lab2_1_2"></a></p><h3>2.1 基本操作</h3>
<div class="jb51code"><pre class="brush:java;">// 设置值
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&lt;String, String&gt; map = new HashMap&lt;&gt;();
redisTemplate.opsForValue().multiSet(map);
// 批量获取
List&lt;Object&gt; values = redisTemplate.opsForValue().multiGet(Arrays.asList("key1", "key2"));</pre></div>
<p class="maodian"><a name="_lab2_1_3"></a></p><h3>2.2 数值操作</h3>
<div class="jb51code"><pre class="brush:java;">// 递增
Long incremented = redisTemplate.opsForValue().increment("counter", 1);
// 递减
Long decremented = redisTemplate.opsForValue().decrement("counter", 1);
// 浮点数增加
Double doubleValue = redisTemplate.opsForValue().increment("doubleKey", 1.5);</pre></div>
<p class="maodian"><a name="_label2"></a></p><h2>三、Hash 类型操作</h2>
<div class="jb51code"><pre class="brush:java;">// 设置单个 field
redisTemplate.opsForHash().put("hashKey", "field", "value");
// 获取单个 field
Object fieldValue = redisTemplate.opsForHash().get("hashKey", "field");
// 设置多个 field
Map&lt;String, String&gt; hashMap = new HashMap&lt;&gt;();
redisTemplate.opsForHash().putAll("hashKey", hashMap);
// 获取所有 field
Map&lt;Object, Object&gt; allEntries = redisTemplate.opsForHash().entries("hashKey");
// 删除 field
redisTemplate.opsForHash().delete("hashKey", "field1", "field2");
// 判断 field 是否存在
Boolean hasField = redisTemplate.opsForHash().hasKey("hashKey", "field");
// 获取所有 keys(fields)
Set&lt;Object&gt; hashKeys = redisTemplate.opsForHash().keys("hashKey");
// 获取所有 values
List&lt;Object&gt; hashValues = redisTemplate.opsForHash().values("hashKey");
// 获取大小
Long size = redisTemplate.opsForHash().size("hashKey");</pre></div>
<p class="maodian"><a name="_label3"></a></p><h2>四、List 类型操作</h2>
<div class="jb51code"><pre class="brush:java;">// 左侧插入
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&lt;Object&gt; 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");</pre></div>
<p class="maodian"><a name="_label4"></a></p><h2>五、Set 类型操作</h2>
<div class="jb51code"><pre class="brush:java;">// 添加元素
redisTemplate.opsForSet().add("setKey", "value1", "value2");
// 获取所有元素
Set&lt;Object&gt; 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&lt;Object&gt; intersect = redisTemplate.opsForSet().intersect("set1", "set2");
// 求并集
Set&lt;Object&gt; union = redisTemplate.opsForSet().union("set1", "set2");
// 求差集
Set&lt;Object&gt; difference = redisTemplate.opsForSet().difference("set1", "set2");</pre></div>
<p class="maodian"><a name="_label5"></a></p><h2>六、ZSet(有序集合)操作</h2>
<div class="jb51code"><pre class="brush:java;">// 添加元素(带分数)
redisTemplate.opsForZSet().add("zsetKey", "value", 100);
// 获取分数
Double score = redisTemplate.opsForZSet().score("zsetKey", "value");
// 增加分数
Double newScore = redisTemplate.opsForZSet().incrementScore("zsetKey", "value", 10);
// 按排名范围获取
Set&lt;Object&gt; rangeByRank = redisTemplate.opsForZSet().range("zsetKey", 0, -1);
// 按分数范围获取
Set&lt;Object&gt; 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);</pre></div>
<p class="maodian"><a name="_label6"></a></p><h2>七、事务操作</h2>
<div class="jb51code"><pre class="brush:java;">// 开启事务支持
redisTemplate.setEnableTransactionSupport(true);
// 执行事务
List&lt;Object&gt; results = redisTemplate.execute(new SessionCallback&lt;List&lt;Object&gt;&gt;() {
    @Override
    public List&lt;Object&gt; execute(RedisOperations operations) throws DataAccessException {
      operations.multi();// 开始事务
      operations.opsForValue().set("key1", "value1");
      operations.opsForValue().set("key2", "value2");
      return operations.exec();// 执行事务
    }
});</pre></div>
<p class="maodian"><a name="_label7"></a></p><h2>八、管道操作</h2>
<div class="jb51code"><pre class="brush:sql;">// 使用管道批量操作
List&lt;Object&gt; results = redisTemplate.executePipelined(new RedisCallback&lt;Object&gt;() {
    @Override
    public Object doInRedis(RedisConnection connection) throws DataAccessException {
      connection.openPipeline();
      connection.set("key1".getBytes(), "value1".getBytes());
      connection.set("key2".getBytes(), "value2".getBytes());
      return null;
    }
});
</pre></div>
<p class="maodian"><a name="_label8"></a></p><h2>九、发布订阅</h2>
<div class="jb51code"><pre class="brush:java;">// 发送消息到频道
redisTemplate.convertAndSend("channelName", "message content");
// 接收消息需要配置 MessageListener(通常通过配置类实现)</pre></div>
<p class="maodian"><a name="_label9"></a></p><h2>十、Lua脚本执行</h2>
<div class="jb51code"><pre class="brush:java;">// 执行 Lua 脚本
DefaultRedisScript&lt;Long&gt; script = new DefaultRedisScript&lt;&gt;();
script.setScriptText("return redis.call('get', KEYS)");
script.setResultType(Long.class);
Long result = redisTemplate.execute(script, Arrays.asList("key"));</pre></div>
頁: [1]
查看完整版本: redis 中 redisTemplate 的所有操作与函数详解