为什么选择Spring Data Redis?
Spring框架,是引领潮流的全栈Java/JEE应用框架。它提供了一个轻量级容器,一种非侵入式的编程模型 -- 这是由依赖注入、AOP、以及便携的服务抽象开启的。
NoSQL存储,提供了传统RDBMS之外的一种选择。
SDR框架,使得利用Redis键值存储非常简单,消除了繁复冗余的任务和呆板的代码(指获取连接、释放资源)。
如同前面所解释的,SDR提供了Spring框架和Redis键值存储的集成。因此,掌握这两个框架非常重要。
虽然本文档的每一部分都提供了相关资源的连接,但最好还是提前熟悉下。
使用RedisTemplate操作Objects(主要)
多数用户会喜欢使用RedisTemplate和相应的包org.springframework.data.redis.core,该template是redis模块的中心类——由于丰富的功能集。该template为redis交互提供了一个高级别的抽象。当RedisConnection提供了低级别的方法来接受和返还二进制值(byte arrays)时,该template负责了序列化和连接管理,将用户从这里细节中解放了出来。
更多地,该template提供了操作视图(following the grouping from Redis command
reference) -- 提供了丰富的接口 来操作特定类型或特定key(通过KeyBound接口),如下:
Table 1. Operational views
一旦配置了,该template就是线程安全的,可被多个实例复用。(redis是单例的)
开箱即用,RedisTemplate使用一个机遇java的序列化器,用于多数操作。这意味着,该tempalte读写的任意object会通过java来序列化和反序列化。
该template的序列化机制可以轻松的修改,该redis模块提供了几个实现,在org.springframework.data.redis.serializer包中。
也可以不使用序列化器,直接让RedisTemplate使用原生byte数组,只需要将enableDefaultSerializer设为false即可。
注意,该template要求所有的key都不能是null,但value可以是null -- 只要底层的序列化器接受。
Redis 可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串)、List(列表)、Set(集合)、Hash(散列)和 Zset(有序集合)。
总括: redisTemplate.opsForValue();//操作字符串
redisTemplate.opsForHash();//操作hash
redisTemplate.opsForList();//操作list
redisTemplate.opsForSet();//操作set
redisTemplate.opsForZSet();//操作有序set
Redis中opsForValue()方法的使用介绍(简单说介绍几个):
1、set(K key, V value)
新增一个字符串类型的值,key是键,value是值。
Java代码
- redisTemplate.opsForValue().set("stringValue","bbb");
2、get(Object key)
获取key键对应的值。
Java代码
- String stringValue = redisTemplate.opsForValue().get("stringValue")+"";
- System.out.println("通过get(Object key)方法获取set(K key, V value)方法新增的字符串值:" + stringValue);
3、append(K key, String value)
在原有的值基础上新增字符串到末尾。
Java代码
- redisTemplate.opsForValue().append("stringValue","aaa");
- String stringValueAppend = redisTemplate.opsForValue().get("stringValue")+"";
- System.out.println("通过append(K key, String value)方法修改后的字符串:"+stringValueAppend);
4、get(K key, long start, long end)
截取key键对应值得字符串,从开始下标位置开始到结束下标的位置(包含结束下标)的字符串。
Java代码
- String cutString = redisTemplate.opsForValue().get("stringValue",0,3);
- System.out.println("通过get(K key, long start, long end)方法获取截取的字符串:"+cutString);
5、getAndSet(K key, V value)
获取原来key键对应的值并重新赋新值。
Java代码
- String oldAndNewStringValue = redisTemplate.opsForValue().getAndSet("stringValue","ccc")+"";
- System.out.print("通过getAndSet(K key, V value)方法获取原来的" + oldAndNewStringValue + ",");
- String newStringValue = redisTemplate.opsForValue().get("stringValue")+"";
- System.out.println("修改过后的值:"+newStringValue);
6、setBit(K key, long offset, boolean value)
key键对应的值value对应的ascii码,在offset的位置(从左向右数)变为value。
Java代码
- redisTemplate.opsForValue().setBit("stringValue",1,false);
- newStringValue = redisTemplate.opsForValue().get("stringValue")+"";
- System.out.println("通过setBit(K key,long offset,boolean value)方法修改过后的值:"+newStringValue);
7、getBit(K key, long offset)
判断指定的位置ASCII码的bit位是否为1。
Java代码
- boolean bitBoolean = redisTemplate.opsForValue().getBit("stringValue",1);
- System.out.println("通过getBit(K key,long offset)方法判断指定bit位的值是:" + bitBoolean);
8、size(K key)
获取指定字符串的长度。
Java代码
- Long stringValueLength = redisTemplate.opsForValue().size("stringValue");
- System.out.println("通过size(K key)方法获取字符串的长度:"+stringValueLength);
9、increment(K key, double delta)
以增量的方式将double值存储在变量中。
Java代码
- double stringValueDouble = redisTemplate.opsForValue().increment("doubleValue",5);
- System.out.println("通过increment(K key, double delta)方法以增量方式存储double值:" + stringValueDouble);
10、increment(K key, long delta)
以增量的方式将long值存储在变量中。
Java代码
- double stringValueLong = redisTemplate.opsForValue().increment("longValue",6);
- System.out.println("通过increment(K key, long delta)方法以增量方式存储long值:" + stringValueLong);
11、setIfAbsent(K key, V value)
如果键不存在则新增,存在则不改变已经有的值。
Java代码
- boolean absentBoolean = redisTemplate.opsForValue().setIfAbsent("absentValue","fff");
- System.out.println("通过setIfAbsent(K key, V value)方法判断变量值absentValue是否存在:" + absentBoolean);
- if(absentBoolean){
- String absentValue = redisTemplate.opsForValue().get("absentValue")+"";
- System.out.print(",不存在,则新增后的值是:"+absentValue);
- boolean existBoolean = redisTemplate.opsForValue().setIfAbsent("absentValue","eee");
- System.out.print(",再次调用setIfAbsent(K key, V value)判断absentValue是否存在并重新赋值:" + existBoolean);
- if(!existBoolean){
- absentValue = redisTemplate.opsForValue().get("absentValue")+"";
- System.out.print("如果存在,则重新赋值后的absentValue变量的值是:" + absentValue);
- }
- }
12、set(K key, V value, long timeout, TimeUnit unit)
设置变量值的过期时间。
Java代码
- redisTemplate.opsForValue().set("timeOutValue","timeOut",5,TimeUnit.SECONDS);
- String timeOutValue = redisTemplate.opsForValue().get("timeOutValue")+"";
- System.out.println("通过set(K key, V value, long timeout, TimeUnit unit)方法设置过期时间,过期之前获取的数据:"+timeOutValue);
- Thread.sleep(5*1000);
- timeOutValue = redisTemplate.opsForValue().get("timeOutValue")+"";
- System.out.print(",等待10s过后,获取的值:"+timeOutValue);
13、set(K key, V value, long offset)
覆盖从指定位置开始的值。
Java代码
- redisTemplate.opsForValue().set("absentValue","dd",1);
- String overrideString = redisTemplate.opsForValue().get("absentValue")+"";
- System.out.println("通过set(K key, V value, long offset)方法覆盖部分的值:"+overrideString);
14、multiSet(Map<? extends K,? extends V> map)
设置map集合到redis。
Java代码
- Map valueMap = new HashMap();
- valueMap.put("valueMap1","map1");
- valueMap.put("valueMap2","map2");
- valueMap.put("valueMap3","map3");
- redisTemplate.opsForValue().multiSet(valueMap);
15、multiGet(Collection<K> keys)
根据集合取出对应的value值。
Java代码
- //根据List集合取出对应的value值
- List paraList = new ArrayList();
- paraList.add("valueMap1");
- paraList.add("valueMap2");
- paraList.add("valueMap3");
- List<String> valueList = redisTemplate.opsForValue().multiGet(paraList);
- for (String value : valueList){
- System.out.println("通过multiGet(Collection<K> keys)方法获取map值:" + value);
- }
16、multiSetIfAbsent(Map<? extends
K,? extends
V> map)
如果对应的map集合名称不存在,则添加,如果存在则不做修改。
Java代码
- Map valueMap = new HashMap();
- valueMap.put("valueMap1","map1");
- valueMap.put("valueMap2","map2");
- valueMap.put("valueMap3","map3");
- redisTemplate.opsForValue().multiSetIfAbsent(valueMap);