RedisTemplate.opsForValue 常用方法

1、set(K key, V value)

新增一个字符串类型的值,key是键,value是值。

  redisTemplate.opsForValue().set("stringValue","bbb");

2、get(Object key)

获取key键对应的值

  1. String stringValue = redisTemplate.opsForValue().get("stringValue")+"";
  2. System.out.println("通过get(Object key)方法获取set(K key, V value)方法新增的字符串值:" + stringValue);

3、append(K key, String value)

在原有的值基础上新增字符串到末尾。

  1. redisTemplate.opsForValue().append("stringValue","aaa");
  2. String stringValueAppend = redisTemplate.opsForValue().get("stringValue")+"";
  3. System.out.println("通过append(K key, String value)方法修改后的字符串:"+stringValueAppend);

4、get(K key, long start, long end)

截取key键对应值得字符串,从开始下标位置开始到结束下标的位置(包含结束下标)的字符串。

  1. String cutString = redisTemplate.opsForValue().get("stringValue",0,3);
  2. System.out.println("通过get(K key, long start, long end)方法获取截取的字符串:"+cutString);

5、getAndSet(K key, V value)

获取原来key键对应的值并重新赋新值。

  1. String oldAndNewStringValue = redisTemplate.opsForValue().getAndSet("stringValue","ccc")+"";
  2. System.out.print("通过getAndSet(K key, V value)方法获取原来的" + oldAndNewStringValue + ",");
  3. String newStringValue = redisTemplate.opsForValue().get("stringValue")+"";
  4. System.out.println("修改过后的值:"+newStringValue);

6、setBit(K key, long offset, boolean value)

key键对应的值value对应的ascii码,在offset的位置(从左向右数)变为value。

  1. redisTemplate.opsForValue().setBit("stringValue",1,false);
  2. newStringValue = redisTemplate.opsForValue().get("stringValue")+"";
  3. System.out.println("通过setBit(K key,long offset,boolean value)方法修改过后的值:"+newStringValue);

7、getBit(K key, long offset)

判断指定的位置ASCII码的bit位是否为1。

  1. boolean bitBoolean = redisTemplate.opsForValue().getBit("stringValue",1);
  2. System.out.println("通过getBit(K key,long offset)方法判断指定bit位的值是:" + bitBoolean);

8、size(K key)

获取指定字符串的长度。

  1. Long stringValueLength = redisTemplate.opsForValue().size("stringValue");
  2. System.out.println("通过size(K key)方法获取字符串的长度:"+stringValueLength);

9、increment(K key, double delta)

以增量的方式将double值存储在变量中。

  1. double stringValueDouble = redisTemplate.opsForValue().increment("doubleValue",5);
  2. System.out.println("通过increment(K key, double delta)方法以增量方式存储double值:" + stringValueDouble);

10、increment(K key, long delta)

以增量的方式将long值存储在变量中。

  1. double stringValueLong = redisTemplate.opsForValue().increment("longValue",6);
  2. System.out.println("通过increment(K key, long delta)方法以增量方式存储long值:" + stringValueLong);

11、setIfAbsent(K key, V value)

如果键不存在则新增,存在则不改变已经有的值。

  1. boolean absentBoolean = redisTemplate.opsForValue().setIfAbsent("absentValue","fff");
  2. System.out.println("通过setIfAbsent(K key, V value)方法判断变量值absentValue是否存在:" + absentBoolean);
  3. if(absentBoolean){
  4. String absentValue = redisTemplate.opsForValue().get("absentValue")+"";
  5. System.out.print(",不存在,则新增后的值是:"+absentValue);
  6. boolean existBoolean = redisTemplate.opsForValue().setIfAbsent("absentValue","eee");
  7. System.out.print(",再次调用setIfAbsent(K key, V value)判断absentValue是否存在并重新赋值:" + existBoolean);
  8. if(!existBoolean){
  9. absentValue = redisTemplate.opsForValue().get("absentValue")+"";
  10. System.out.print("如果存在,则重新赋值后的absentValue变量的值是:" + absentValue);
  11. }
  12. }

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

设置变量值的过期时间。

  1. redisTemplate.opsForValue().set("timeOutValue","timeOut",5,TimeUnit.SECONDS);
  2. String timeOutValue = redisTemplate.opsForValue().get("timeOutValue")+"";
  3. System.out.println("通过set(K key, V value, long timeout, TimeUnit unit)方法设置过期时间,过期之前获取的数据:"+timeOutValue);
  4. Thread.sleep(5*1000);
  5. timeOutValue = redisTemplate.opsForValue().get("timeOutValue")+"";
  6. System.out.print(",等待10s过后,获取的值:"+timeOutValue);

13、set(K key, V value, long offset)

覆盖从指定位置开始的值。

  1. redisTemplate.opsForValue().set("absentValue","dd",1);
  2. String overrideString = redisTemplate.opsForValue().get("absentValue")+"";
  3. System.out.println("通过set(K key, V value, long offset)方法覆盖部分的值:"+overrideString);

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

设置map集合到redis。

  1. Map valueMap = new HashMap();
  2. valueMap.put("valueMap1","map1");
  3. valueMap.put("valueMap2","map2");
  4. valueMap.put("valueMap3","map3");
  5. redisTemplate.opsForValue().multiSet(valueMap);

15、multiGet(Collection<K> keys)

根据集合取出对应的value值。

  1. //根据List集合取出对应的value值
  2. List paraList = new ArrayList();
  3. paraList.add("valueMap1");
  4. paraList.add("valueMap2");
  5. paraList.add("valueMap3");
  6. List<String> valueList = redisTemplate.opsForValue().multiGet(paraList);
  7. for (String value : valueList){
  8. System.out.println("通过multiGet(Collection<K> keys)方法获取map值:" + value);
  9. }

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

如果对应的map集合名称不存在,则添加,如果存在则不做修改。

  1. Map valueMap = new HashMap();
  2. valueMap.put("valueMap1","map1");
  3. valueMap.put("valueMap2","map2");
  4. valueMap.put("valueMap3","map3");
  5. redisTemplate.opsForValue().multiSetIfAbsent(valueMap);

转自:http://357029540.iteye.com/blog/2388965

RedisTemplate.opsForValue 常用方法的更多相关文章

  1. redisTemplate的spring配置以及lua脚本驱动

    最近在使用spring-data-redis的redisTemplate,所以写篇使用记录吧. 1.不用多说,使用maven引入相关依赖,因为项目已经引入其他的 <dependency> ...

  2. 使用RedisTemplate进行Redis存取的工具类设计

    通常在访问量大数据更新频率不高的系统中会使用第三方的缓存组件来降低数据库服务的负载,鉴于模块独立分工独立的考虑,针对缓存组件操作的工作全部应该统一接口对其他业务提供服务,这样业务操作只需要关注业务实现 ...

  3. spring mvc Spring Data Redis RedisTemplate [转]

    http://maven.springframework.org/release/org/springframework/data/spring-data-redis/(spring-data包下载) ...

  4. Spring Data Redis简介以及项目Demo,RedisTemplate和 Serializer详解

    一.概念简介: Redis: Redis是一款开源的Key-Value数据库,运行在内存中,由ANSI C编写,详细的信息在Redis官网上面有,因为我自己通过google等各种渠道去学习Redis, ...

  5. RedisTemplate

    Spring Boot中Jedis几个api返回值的确认 @RequestMapping("/del/{key}") public String del(@PathVariable ...

  6. 如何使用RedisTemplate访问Redis数据结构

    RedisTemplate介绍 spring封装了RedisTemplate对象来进行对redis的各种操作,它支持所有的 redis 原生的api. RedisTemplate在spring代码中的 ...

  7. Spring中使用RedisTemplate操作Redis(spring-data-redis)

    RedisTemplate如何检查一个key是否存在? return getRedisTemplate().hasKey(key); 由一个问题,复习了一下redis 抄自: https://www. ...

  8. springboot使用redisTemplate遇到的问题

    概述 最近工作中新构建了一个项目,用的springboot,由于项目中要使用各种各样的缓存,就使用了spring-data-redis,这个东西比我想象中要难使用的多啊,而且我还遇到个问题,就是在用R ...

  9. spring 整合 redis,以及spring的RedisTemplate如何使用

    需要的jar包 spring-data-redis-1.6.2.RELEASE.jar jedis-2.7.2.jar(依赖 commons-pool2-2.3.jar) commons-pool2- ...

随机推荐

  1. JMS入门简介

    一.JMS是什么 1.JMS即Java消息服务(Java Message Service)应用程序接口,是一个Java平台中关于面向消息中间件(MOM)的API,用于在两个应用程序之间,或分布式系统中 ...

  2. wwww

    public class MainActivity extends AppCompatActivity implements XListView.IXListViewListener{ ; priva ...

  3. Java源码之ConcurrentHashMap

    ⑴背景 ConcurrentHashMap是线程安全高效的HashMap.而HashMap在多线程情况下强行使用HashMap的put方法可能会导致程序死循环,使CPU使用率达到100%.(http: ...

  4. scrapy xpath用法

    一.实验环境 1.Windows7x64_SP1 2.anaconda3 + python3.7.3(anaconda集成,不需单独安装) 3.scrapy1.6.0 二.用法举例 1.开启scrap ...

  5. 最小生成树模板题-----P3366 【模板】最小生成树

    题目描述 如题,给出一个无向图,求出最小生成树,如果该图不连通,则输出orz 输入格式 第一行包含两个整数N.M,表示该图共有N个结点和M条无向边.(N<=5000,M<=200000) ...

  6. TCP与UDP的主要特点

    UDP主要特点: (1)UDP是无连接的,即发送数据之前不需要建立连接(当然,发送数据结束时也没有连接可以释放),因此减少了开销和发送数据之前的时延. (2)UDP使用尽最大努力交付,即不保证可靠交付 ...

  7. 利用ShardingSphere-JDBC实现分库分表

    利用ShardingSphere-JDBC实现分库分表 1. ShardingSphere概述 1.1 概述 业务发展到一定程度,分库分表是一种必然的要求,分库可以实现资源隔离,分表则可以降低单表数据 ...

  8. 企查查app新增企业数据抓取

    企查查每日新增企业数据抓取尚未完成的工作: 需要自行抓包获取设备id,appid,sign等等 sign和时间戳保持一致即可 把所有的数据库.redis配置 无法自动登录,账号需要独立 redis数据 ...

  9. .net测试篇之Moq行为配置

    系列目录 我们前面说过.Moq在创建模拟对象的时候,简单对象赋值默认值,引用对象赋值为null,但是有些时候接口里面还包含另一个接口对象,我们知道Moq是可以模拟一个接口对象的,我们可以通过配置让Mo ...

  10. ECMAScript---布尔类型、null、undefined详解

    布尔类型中 至只有 true和false 在开发中它是非常重要的两个值,尤其是在条件判断中 如何把其他类型转换为布尔类型? 1.Boolean() Boolean(1); //true Boolean ...