redis Template.opsForValue()中方法实例详解

 更新时间:2023年05月24日 10:07:29   作者:FighterLiu  
这篇文章主要介绍了redis Template.opsForValue()中方法讲解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

查看源码可以看到redisTemplate.opsForValue()中的方法都定义在ValueOperations<K, V> 中,该接口中一共有17个方法:

public interface ValueOperations<K, V> {
	void set(K key, V value);
	void set(K key, V value, long timeout, TimeUnit unit);
	Boolean setIfAbsent(K key, V value);
	void multiSet(Map<? extends K, ? extends V> map);
	Boolean multiSetIfAbsent(Map<? extends K, ? extends V> map);
	V get(Object key);
	V getAndSet(K key, V value);
	List<V> multiGet(Collection<K> keys);
	Long increment(K key, long delta);
	Double increment(K key, double delta);
	Integer append(K key, String value);
	String get(K key, long start, long end);
	void set(K key, V value, long offset);
	Long size(K key);
	Boolean setBit(K key, long offset, boolean value);
	Boolean getBit(K key, long offset);
	RedisOperations<K, V> getOperations();
}

下面我们一个一个来讲解

void set(K key, V value)

方法含义:新增一个字符串类型的值,key是键,value是值

使用方法:

redisTemplate.opsForValue().set("stringkey", "stringvalue");

void set(K key, V value, long timeout, TimeUnit unit)

方法含义:新增一个字符串类型的值,并且设置变量值的过期时间。key是键,value是值,timeout 过期时间,unit 过期时间单位。

unit 过期时间单位取值如下:

DAYS:天时间单元代表24小时
HOURS:小时时间单元代表60分钟
MICROSECONDS:微秒时间单元代表千分之一毫秒
MILLISECONDS:毫秒时间单元代表千分之一秒
MINUTES:分钟时间单元代表60秒
NANOSECONDS:纳秒时间单元代表千分之一微秒
SECONDS:时间单元代表1秒

使用方法,把timeoutkey对应的值设置过期时间为10秒:

redisTemplate.opsForValue().set("timeoutkey", "timeoutvalue", 10, TimeUnit.SECONDS);

Boolean setIfAbsent(K key, V value)

方法含义:如果键不存在则新增,存在则不改变已经有的值。

使用方法:

redisTemplate.opsForValue().setIfAbsent("newkey", "newvalue");

V get(Object key)

方法含义:获取key键对应的值

使用方法:

redisTemplate.opsForValue().get("stringkey");

String get(K key, long start, long end)

方法含义:截取key键对应值的字符串,从开始下标位置开始到结束下标的位置(包含结束下标)的字符串。下标从1开始,如果stringkey对应的值为value,那么下面这个方法返回为:al

使用方法:

redisTemplate.opsForValue().get("stringkey", 2, 3);

V getAndSet(K key, V value)

方法含义:获取原来key键对应的值并重新赋新值

使用方法:

redisTemplate.opsForValue().getAndSet("stringkey", "newvalue");

void set(K key, V value, long offset)

方法含义:覆盖从指定位置开始的值

使用方法:

redisTemplate.opsForValue().set("stringkey", "a", 1); 

如下三个方法放在一起讲:

void multiSet(Map<? extends K, ? extends V> map)

Boolean multiSetIfAbsent(Map<? extends K, ? extends V> map)

List<V> multiGet(Collection<K> keys)

方法含义:multiSet:设置map集合到redis;multiSetIfAbsent:如果对应的map集合名称不存在,则添加,如果存在则不做修改;multiGet:根据集合取出对应的value值。

先使用multiSet设置相应的值,如下:

Map map = new HashMap();
        map.put("key1", "value1");
        map.put("key2", "value2");
        map.put("key3", "value3");
        redisTemplate.opsForValue().multiSet(map);

在使用multiGet获得相应的值

List list = new ArrayList();
        list.add("key1");
        list.add("key2");
        list.add("key3");
        List<String> valueList = redisTemplate.opsForValue().multiGet(list);
        for (String value2 : valueList) {
            System.out.println("通过multiGet(Collection<K> keys)方法获取map值:" + value2);
        }

打印结果如下:

使用multiSetIfAbsent 设置相应的值,map集合中的key与之前一样,valeu设置的不一样

Map map1 = new HashMap();
        map1.put("key1", "value11");
        map1.put("key2", "value22");
        map1.put("key3", "value33");
        List list1 = new ArrayList();
        list1.add("key1");
        list1.add("key2");
        list1.add("key3");
        redisTemplate.opsForValue().multiSetIfAbsent(map1);
        List<String> valueList1 = redisTemplate.opsForValue().multiGet(list1);
        for (String value1 : valueList1) {
            System.out.println("通过multiGet(Collection<K> keys)方法获取map值:" + value1);
        }

打印结果如下,我们可以看到没有做任何修改

使用multiSetIfAbsent 设置相应的值,map集合中的key,valeu设置的都不一样

Map map1 = new HashMap();
        map1.put("key11", "value11");
        map1.put("key21", "value22");
        map1.put("key31", "value33");
        List list1 = new ArrayList();
        list1.add("key11");
        list1.add("key21");
        list1.add("key31");
        redisTemplate.opsForValue().multiSetIfAbsent(map1);
        List<String> valueList1 = redisTemplate.opsForValue().multiGet(list1);
        for (String value1 : valueList1) {
            System.out.println("通过multiGet(Collection<K> keys)方法获取map值:" + value1);
        }

打印结果如下,我们可以看到新增了3个key:

备注说明:multiSetIfAbsent 只要map中有一个key存在,则都不做修改。

Long increment(K key, long delta)
Double increment(K key, double delta)

方法含义:以增量的方式将值存储在变量中,第二个参数为递增因子

使用方法:

redisTemplate.opsForValue().set("doublevalue", 1);
        redisTemplate.opsForValue().increment("doublevalue", 1.2);//以1.2递增,递增后为2.2
        redisTemplate.opsForValue().increment("doublevalue", 1);//以1递增,递增后为3.2

Integer append(K key, String value)

方法含义:在原有的值基础上新增字符串到末尾

使用方法:

redisTemplate.opsForValue().set("stringkey", "value");
redisTemplate.opsForValue().append("stringkey", "appendValue");

备注说明:如果append方法不起效果需要进行配置将 template.setValueSerializer(jackson2JsonRedisSerializer);修改为:template.setValueSerializer(new StringRedisSerializer());这个是因为序列化的原因,RedisTemplateput进去的值是序列化成二进制后的,但是append的值是直接加的。所以get的时候反序列化直接变成空值了。如果你存的值是字符串类型,建议直接使用StringRedisTemplate,这个不会序列化成二进制,append是可以用的。而且直接在redis客户端存的值也能取到

Long size(K key)

方法含义:获取指定字符串的长度

使用方法:

Long size = redisTemplate.opsForValue().size("stringkey");

Boolean setBit(K key, long offset, boolean value)
Boolean getBit(K key, long offset)

方法含义:setBit:key键对应的值value对应的ascii码,在offset的位置(从左向右数)变为value;getBit:判断指定的位置ASCII码的bit位是否为true或者false

使用方法:

redisTemplate.opsForValue().set("stringkey", "value");
        redisTemplate.opsForValue().setBit("stringkey", 1, true);
        boolean flag= redisTemplate.opsForValue().getBit("stringkey", 1);

到此这篇关于redis Template.opsForValue()中方法讲解的文章就介绍到这了,更多相关redis Template.opsForValue()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决Redis缓存击穿问题(互斥锁、逻辑过期)

    解决Redis缓存击穿问题(互斥锁、逻辑过期)

    本文介绍了背景缓存击穿问题及两种常见解决方案:互斥锁与逻辑过期,互斥锁通过获取锁来确保数据最新,但响应速度慢,可能有死锁风险,逻辑过期利用过期字段判断缓存是否过期,提高性能但不保证一致性,需要额外内存,通过JMeter测试,两种方案都能有效缓解缓存击穿问题
    2026-02-02
  • Redis不同数据类型的命令语句详解

    Redis不同数据类型的命令语句详解

    这篇文章主要介绍了Redis不同数据类型的命令语句,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • 详解redis在服务器linux下启动的相关命令(安装和配置)

    详解redis在服务器linux下启动的相关命令(安装和配置)

    这篇文章主要介绍了redis在服务器linux下的启动的相关命令(安装和配置),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-08-08
  • redis服务启动与停止方式

    redis服务启动与停止方式

    这篇文章主要介绍了redis服务启动与停止方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • Redis排序后MySQL查询乱序问题的原因及解决方法

    Redis排序后MySQL查询乱序问题的原因及解决方法

    在日常开发中,我们经常会遇到需要按特定顺序展示数据的场景,为了提升性能,很多开发者会用Redis做排序存储,再用MySQL查询详细数据,这篇博客就详细拆解这个高频问题,从错误场景、根本原因,到具体解决方案,需要的朋友可以参考下
    2026-03-03
  • Redis持久化解读

    Redis持久化解读

    Redis是一种内存级数据库,提供高速读写性能,但数据易失,它支持三种持久化方式:RDB(快照持久化)、AOF(追加文件持久化)和混合持久化,RDB通过快照将数据保存到磁盘,AOF记录所有写操作命令,混合持久化结合两者优点
    2025-01-01
  • Redis 的内存淘汰策略和过期删除策略的区别

    Redis 的内存淘汰策略和过期删除策略的区别

    这篇文章主要介绍了Redis 的内存淘汰策略和过期删除策略的区别,Redis 是可以对 key 设置过期时间的,因此需要有相应的机制将已过期的键值对删除,而做这个工作的就是过期键值删除策略
    2022-07-07
  • Redis7.0部署集群的实现步骤

    Redis7.0部署集群的实现步骤

    本文主要介绍了Redis7.0部署集群的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • redis集群部署方案和redis常用命令

    redis集群部署方案和redis常用命令

    本文介绍了部署Redis集群的详细步骤以及常用命令和管理操作,同时提醒了生产环境中的注意事项,如配置持久化、密码认证和时钟同步,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2026-01-01
  • Redis实战之Redis实现异步秒杀优化详解

    Redis实战之Redis实现异步秒杀优化详解

    这篇文章主要给大家介绍了Redis实战之Redis实现异步秒杀优化方法,文章通过图片和代码介绍的非常详细,对大家的学习或工作有一定的帮助,感兴趣的同学可以自己动手试一下
    2023-09-09

最新评论