RedisTemplate常用方法总结

[toc]

很多公司都将redisTemplate进行了封装,封装成业务所需要的RedisUtil工具类方便进行调用,本篇文章总结了redisTemplate常用的一些方法。

Redis常用的数据类型:

  • String

  • Hash

  • List

  • Set

  • zSet

  • Sorted set

String类型

判断是否有key所对应的值,有则返回true,没有则返回false


redisTemplate.hasKey(key)

有则取出key值所对应的值


redisTemplate.opsForValue().get(key)

删除单个key值


redisTemplate.delete(key)

批量删除key


redisTemplate.delete(keys) //其中keys:Collection<K> keys

将当前传入的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值,返回一个Set<K>集合类型


public Set<String> getPatternKey(String pattern) {

    return redisTemplate.keys(pattern);

}

修改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)

Hash类型

Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。

Redis 中每个 hash 可以存储 2^32 - 1 键值对(40多亿)。

获取变量中的指定map键是否有值,如果存在该map键则获取值,没有则返回null。


redisTemplate.opsForHash().get(key, field)

获取变量中的键值对


public Map<Object, Object> hGetAll(String key) {

    return redisTemplate.opsForHash().entries(key);

}

新增hashMap值


redisTemplate.opsForHash().put(key, hashKey, value)

以map集合的形式添加键值对


public void hPutAll(String key, Map<String, String> maps) {

    redisTemplate.opsForHash().putAll(key, maps);

}

仅当hashKey不存在时才设置


public Boolean hashPutIfAbsent(String key, String hashKey, String value) {

    return redisTemplate.opsForHash().putIfAbsent(key, hashKey, value);

}

删除一个或者多个hash表字段


public Long hashDelete(String key, Object... fields) {

    return redisTemplate.opsForHash().delete(key, fields);

}

查看hash表中指定字段是否存在


public boolean hashExists(String key, String field) {

    return redisTemplate.opsForHash().hasKey(key, field);

}

给哈希表key中的指定字段的整数值加上增量increment


public Long hashIncrBy(String key, Object field, long increment) {

    return redisTemplate.opsForHash().increment(key, field, increment);

}


public Double hIncrByDouble(String key, Object field, double delta) {

    return redisTemplate.opsForHash().increment(key, field, delta);

}

获取所有hash表中字段


redisTemplate.opsForHash().keys(key)

获取hash表中字段的数量


redisTemplate.opsForHash().size(key)

获取hash表中存在的所有的值


public List<Object> hValues(String key) {

    return redisTemplate.opsForHash().values(key);

}

匹配获取键值对,ScanOptions.NONE为获取全部键对


public Cursor<Entry<Object, Object>> hashScan(String key, ScanOptions options) {

    return redisTemplate.opsForHash().scan(key, options);

}

List类型

通过索引获取列表中的元素


redisTemplate.opsForList().index(key, index)

获取列表指定范围内的元素(start开始位置, 0是开始位置,end 结束位置, -1返回所有)


redisTemplate.opsForList().range(key, start, end)

存储在list的头部,即添加一个就把它放在最前面的索引处


redisTemplate.opsForList().leftPush(key, value)

把多个值存入List中(value可以是多个值,也可以是一个Collection<V> value)


redisTemplate.opsForList().leftPushAll(key, value)

List存在的时候再加入


redisTemplate.opsForList().leftPushIfPresent(key, value)

如果pivot处值存在则在pivot前面添加


redisTemplate.opsForList().leftPush(key, pivot, value)

按照先进先出的顺序来添加(value可以是多个值,或者是Collection<V> var2)


redisTemplate.opsForList().rightPush(key, value)


redisTemplate.opsForList().rightPushAll(key, value)

在pivot元素的右边添加值


redisTemplate.opsForList().rightPush(key, pivot, value)

设置指定索引处元素的值


redisTemplate.opsForList().set(key, index, value)

移除并获取列表中第一个元素(如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止)


redisTemplate.opsForList().leftPop(key)


redisTemplate.opsForList().leftPop(key, timeout, unit)

移除并获取列表最后一个元素


redisTemplate.opsForList().rightPop(key)


redisTemplate.opsForList().rightPop(key, timeout, unit)

从一个队列的右边弹出一个元素并将这个元素放入另一个指定队列的最左边


redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey)


redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey, timeout, unit)

删除集合中值等于value的元素(index=0, 删除所有值等于value的元素; index>0, 从头部开始删除第一个值等于value的元素; index<0, 从尾部开始删除第一个值等于value的元素)


redisTemplate.opsForList().remove(key, index, value)

将List列表进行剪裁


redisTemplate.opsForList().trim(key, start, end)

获取当前key的List列表长度


redisTemplate.opsForList().size(key)

Set类型

添加元素


redisTemplate.opsForSet().add(key, values)

移除元素(单个值、多个值)


redisTemplate.opsForSet().remove(key, values)

删除并且返回一个随机的元素


redisTemplate.opsForSet().pop(key)

获取集合的大小


redisTemplate.opsForSet().size(key)

判断集合是否包含value


redisTemplate.opsForSet().isMember(key, value)

获取两个集合的交集(key对应的无序集合与otherKey对应的无序集合求交集)


redisTemplate.opsForSet().intersect(key, otherKey)

获取多个集合的交集(Collection<K> var2)


redisTemplate.opsForSet().intersect(key, otherKeys)

key集合与otherKey集合的交集存储到destKey集合中(其中otherKey可以为单个值或者集合)


redisTemplate.opsForSet().intersectAndStore(key, otherKey, destKey)

key集合与多个集合的交集存储到destKey无序集合中


redisTemplate.opsForSet().intersectAndStore(key, otherKeys, destKey)

获取两个或者多个集合的并集(otherKeys可以为单个值或者是集合)


redisTemplate.opsForSet().union(key, otherKeys)

key集合与otherKey集合的并集存储到destKey中(otherKeys可以为单个值或者是集合)


redisTemplate.opsForSet().unionAndStore(key, otherKey, destKey)

获取两个或者多个集合的差集(otherKeys可以为单个值或者是集合)


redisTemplate.opsForSet().difference(key, otherKeys)

差集存储到destKey中(otherKeys可以为单个值或者集合)


redisTemplate.opsForSet().differenceAndStore(key, otherKey, destKey)

随机获取集合中的一个元素


redisTemplate.opsForSet().randomMember(key)

获取集合中的所有元素


redisTemplate.opsForSet().members(key)

随机获取集合中count个元素


redisTemplate.opsForSet().randomMembers(key, count)

获取多个key无序集合中的元素(去重),count表示个数


redisTemplate.opsForSet().distinctRandomMembers(key, count)

遍历set类似于Interator(ScanOptions.NONE为显示所有的)


redisTemplate.opsForSet().scan(key, options)

zSet类型

ZSetOperations提供了一系列方法对有序集合进行操作

添加元素(有序集合是按照元素的score值由小到大进行排列)


redisTemplate.opsForZSet().add(key, value, score)

删除对应的value,value可以为多个值


redisTemplate.opsForZSet().remove(key, values)

增加元素的score值,并返回增加后的值


redisTemplate.opsForZSet().incrementScore(key, value, delta)

返回元素在集合的排名,有序集合是按照元素的score值由小到大排列


redisTemplate.opsForZSet().rank(key, value)

返回元素在集合的排名,按元素的score值由大到小排列


redisTemplate.opsForZSet().reverseRank(key, value)

获取集合中给定区间的元素(start 开始位置,end 结束位置, -1查询所有)


redisTemplate.opsForZSet().reverseRangeWithScores(key, start,end)

按照Score值查询集合中的元素,结果从小到大排序


redisTemplate.opsForZSet().reverseRangeByScore(key, min, max)


redisTemplate.opsForZSet().reverseRangeByScoreWithScores(key, min, max)

//返回值为:Set<ZSetOperations.TypedTuple<V>>

从高到低的排序集中获取分数在最小和最大值之间的元素


redisTemplate.opsForZSet().reverseRangeByScore(key, min, max, start, end)

根据score值获取集合元素数量


redisTemplate.opsForZSet().count(key, min, max)

获取集合的大小


redisTemplate.opsForZSet().size(key)


redisTemplate.opsForZSet().zCard(key)

获取集合中key、value元素对应的score值


redisTemplate.opsForZSet().score(key, value)

移除指定索引位置处的成员


redisTemplate.opsForZSet().removeRange(key, start, end)

移除指定score范围的集合成员


redisTemplate.opsForZSet().removeRangeByScore(key, min, max)

获取key和otherKey的并集并存储在destKey中(其中otherKeys可以为单个字符串或者字符串集合)


redisTemplate.opsForZSet().unionAndStore(key, otherKey, destKey)

获取key和otherKey的交集并存储在destKey中(其中otherKeys可以为单个字符串或者字符串集合)


redisTemplate.opsForZSet().intersectAndStore(key, otherKey, destKey)

遍历集合(和iterator一模一样)


Cursor<TypedTuple<Object>> scan = opsForZSet.scan("test3", ScanOptions.NONE);

        while (scan.hasNext()){

            ZSetOperations.TypedTuple<Object> item = scan.next();

            System.out.println(item.getValue() + ":" + item.getScore());

        }

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352