Redis简介
redis是一款开源的Key-Value数据库,运行在内存中,由C语言编写。企业开发通常采用Redis来实现缓存。同类的产品还有memcache 、memcached 等。
Spring Data Redis
Spring-data-redis是spring大家族的一部分,提供了在srping应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,RedisTemplate提供了redis各种操作、异常处理及序列化,支持发布订阅,并对spring 3.1 cache进行了实现。 spring-data-redis针对jedis提供了如下功能:
连接池自动管理,提供了一个高度封装的“RedisTemplate”类 针对jedis客户端中大量api进行了归类封装,将同一类型操作封装为operation接口,将事务操作封装,有容器控制。针对数据的“序列化/反序列化”,提供了多种可选择策略(RedisSerializer)
- ValueOperations:简单K-V操作
- SetOperations:set类型数据操作
- ZSetOperations:zset类型数据操作
- HashOperations:针对map类型的数据操作
- ListOperations:针对list类型的数据操作
String类型常用方法如下:
判断是否有key所对应的值
格式如下:
redisTemplate.hasKey(key)
返回结果:有则返回true,没有则返回false
取值
根据key值,查询返回对应的值。格式如下:
redisTemplate.opsForValue().get(key)
返回结果:有则取出key值所对应的值
删除单个key值
删除单个key值 格式如下:
redisTemplate.delete(key)
批量删除key
批量删除key格式如下:
redisTemplate.delete(keys)
key值转序列号
将当前传入的key值序列化为byte[]类型
redisTemplate.dump(key)
设置过期时间
设置过期时间
public Boolean expire(String key, long timeout, TimeUnit unit) { return redisTemplate.expire(key, timeout, unit); }
public Boolean expireAt(String key, Date date) { return redisTemplate.expireAt(key, date); }
查找匹配的key值
查找匹配的key值,返回一个Set集合类型
public Set<String> getPatternKey(String pattern) { return redisTemplate.keys(pattern); }
修改key
修改redis中key的名称
public void renameKey(String oldKey, String newKey) { redisTemplate.rename(oldKey, newKey); }
返回传入key所存储的值的类型
public DataType getKeyType(String key) { return redisTemplate.type(key); }
如果旧值存在时,将旧值改为新值
public Boolean renameOldKeyIfAbsent(String oldKey, String newKey) { return redisTemplate.renameIfAbsent(oldKey, newKey); }
从redis中随机取出一个key
redisTemplate.randomKey()
返回当前key所对应的剩余过期时间
public Long getExpire(String key) { return redisTemplate.getExpire(key); }
返回剩余过期时间并且指定时间单位
public Long getExpire(String key, TimeUnit unit) { return redisTemplate.getExpire(key, unit); }
将key持久化保存
public Boolean persistKey(String key) { return redisTemplate.persist(key); }
将当前数据库的key移动到指定redis中数据库当中
public Boolean moveToDbIndex(String key, int dbIndex) { return redisTemplate.move(key, dbIndex); }
设置当前的key以及value值
redisTemplate.opsForValue().set(key, value)
设置当前的key以及value值并且设置过期时间
redisTemplate.opsForValue().set(key, value, timeout, unit)
返回key中字符串的子字符
public String getCharacterRange(String key, long start, long end) { return redisTemplate.opsForValue().get(key, start, end); }
将旧的key设置为value,并且返回旧的key
public String setKeyAsValue(String key, String value) { return redisTemplate.opsForValue().getAndSet(key, value); }
批量获取值
public List<String> multiGet(Collection<String> keys) { return redisTemplate.opsForValue().multiGet(keys); }
在原有的值基础上新增字符串到末尾
redisTemplate.opsForValue().append(key, value)
以增量的方式将double值存储在变量中
public Double incrByDouble(String key, double increment) { return redisTemplate.opsForValue().increment(key, increment); }
通过increment(K key, long delta)方法以增量方式存储long值(正值则自增,负值则自减)
public Long incrBy(String key, long increment) { return redisTemplate.opsForValue().increment(key, increment); }
如果对应的map集合名称不存在,则添加否则不做修改
Map valueMap = new HashMap(); valueMap.put("valueMap1","map1"); valueMap.put("valueMap2","map2"); valueMap.put("valueMap3","map3"); redisTemplate.opsForValue().multiSetIfAbsent(valueMap);
设置map集合到redis
Map valueMap = new HashMap(); valueMap.put("valueMap1","map1"); valueMap.put("valueMap2","map2"); valueMap.put("valueMap3","map3"); redisTemplate.opsForValue().multiSet(valueMap);
获取字符串的长度
redisTemplate.opsForValue().size(key)
用 value 参数覆写给定 key 所储存的字符串值,从偏移量 offset 开始
redisTemplate.opsForValue().set(key, value, offset)
重新设置key对应的值,如果存在返回false,否则返回true
redisTemplate.opsForValue().setIfAbsent(key, value)
将值 value 关联到 key,并将 key 的过期时间设为 timeout
redisTemplate.opsForValue().set(key, value, timeout, unit)
将二进制第offset位值变为value
redisTemplate.opsForValue().setBit(key, offset, value)
对key所储存的字符串值,获取指定偏移量上的位(bit)
redisTemplate.opsForValue().getBit(key, offset)
结语
关于RedisTemplate之String类型常用方法详解就已经介绍完了,相信大家对RedisTemplate之String类型常用方法都有了初步的了解,这都是基本的Redis操作,更深入的大家可以继续研究一起探讨。