Redis 数据结构简介

Redis 可以存储键与5种不同数据结构类型之间的映射,这5种数据结构类型分别为String(字符串)、List(列表)、Set(集合)、Hash(散列)和 Zset(有序集合)。

下面来对这5种数据结构类型作简单的介绍:

结构类型 结构存储的值 结构的读写能力
String 可以是字符串、整数或者浮点数 对整个字符串或者字符串的其中一部分执行操作;对象和浮点数执行自增(increment)或者自减(decrement)
List 一个链表,链表上的每个节点都包含了一个字符串 从链表的两端推入或者弹出元素;根据偏移量对链表进行修剪(trim);读取单个或者多个元素;根据值来查找或者移除元素
Set 包含字符串的无序收集器(unorderedcollection),并且被包含的每个字符串都是独一无二的、各不相同 添加、获取、移除单个元素;检查一个元素是否存在于某个集合中;计算交集、并集、差集;从集合里卖弄随机获取元素
Hash 包含键值对的无序散列表 添加、获取、移除单个键值对;获取所有键值对
Zset 字符串成员(member)与浮点数分值(score)之间的有序映射,元素的排列顺序由分值的大小决定 添加、获取、删除单个元素;根据分值范围(range)或者成员来获取元素

Redis 5种数据结构的概念大致介绍到这边,下面将结合Spring封装的RedisTemplate来对这5种数据结构的运用进行演示

RedisTemplate介绍

spring 封装了 RedisTemplate 对象来进行对redis的各种操作,它支持所有的 redis 原生的 api。

RedisTemplate在spring代码中的结构如下:

  1. org.springframework.data.redis.core

  2. Class RedisTemplate<K,V>

  3. java.lang.Object

  4. org.springframework.data.redis.core.RedisAccessor

  5. org.springframework.data.redis.core.RedisTemplate<K,V>

Type Parameters:
K

  • the Redis key type against which the template works (usually a String)
    模板中的Redis key的类型(通常为String)如:RedisTemplate<String, Object>
    注意:如果没特殊情况,切勿定义成RedisTemplate<Object, Object>,否则根据里氏替换原则,使用的时候会造成类型错误 。
    V
  • the Redis value type against which the template works
    模板中的Redis value的类型

RedisTemplate中定义了对5种数据结构操作

  1. redisTemplate.opsForValue();//操作字符串

  2. redisTemplate.opsForHash();//操作hash

  3. redisTemplate.opsForList();//操作list

  4. redisTemplate.opsForSet();//操作set

  5. redisTemplate.opsForZSet();//操作有序set

StringRedisTemplate与RedisTemplate

  • 两者的关系是StringRedisTemplate继承RedisTemplate。

  • 两者的数据是不共通的;也就是说StringRedisTemplate只能管理StringRedisTemplate里面的数据,RedisTemplate只能管理RedisTemplate中的数据。

  • SDR默认采用的序列化策略有两种,一种是String的序列化策略,一种是JDK的序列化策略。

    StringRedisTemplate默认采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。

    RedisTemplate默认采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。

RedisTemplate配置如下:

  1. @Bean

  2. public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory)

  3. {

  4. Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);

  5. ObjectMapper om = new ObjectMapper();

  6. om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);

  7. om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);

  8. jackson2JsonRedisSerializer.setObjectMapper(om);

  9. RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();

  10. template.setConnectionFactory(redisConnectionFactory);

  11. template.setKeySerializer(jackson2JsonRedisSerializer);

  12. template.setValueSerializer(jackson2JsonRedisSerializer);

  13. template.setHashKeySerializer(jackson2JsonRedisSerializer);

  14. template.setHashValueSerializer(jackson2JsonRedisSerializer);

  15. template.afterPropertiesSet();

  16. return template;

  17. }

Redis的String数据结构 (推荐使用StringRedisTemplate)

注意:如果使用RedisTemplate需要更改序列化方式

  1. RedisSerializer<String> stringSerializer = new StringRedisSerializer();

  2. template.setKeySerializer(stringSerializer );

  3. template.setValueSerializer(stringSerializer );

  4. template.setHashKeySerializer(stringSerializer );

  5. template.setHashValueSerializer(stringSerializer );

public interface ValueOperations<K,V>
Redis operations for simple (or in Redis terminology 'string') values.
ValueOperations可以对String数据结构进行操作:

  • set void set(K key, V value);
  1. 使用:redisTemplate.opsForValue().set("name","tom");

  2. 结果:redisTemplate.opsForValue().get("name") 输出结果为tom

  • set void set(K key, V value, long timeout, TimeUnit unit);
  1. 使用:redisTemplate.opsForValue().set("name","tom",10, TimeUnit.SECONDS);

  2. 结果:redisTemplate.opsForValue().get("name")由于设置的是10秒失效,十秒之内查询有结果,十秒之后返回为null

  • set void set(K key, V value, long offset);
    该方法是用 value 参数覆写(overwrite)给定 key 所储存的字符串值,从偏移量 offset 开始
  1. 使用:template.opsForValue().set("key","hello world");

  2. template.opsForValue().set("key","redis", 6);

  3. System.out.println("***************"+template.opsForValue().get("key"));

  4. 结果:***************hello redis

  • setIfAbsent Boolean setIfAbsent(K key, V value);
  1. 使用:System.out.println(template.opsForValue().setIfAbsent("multi1","multi1"));//false multi1之前已经存在

  2. System.out.println(template.opsForValue().setIfAbsent("multi111","multi111"));//true multi111之前不存在

  3. 结果:false

  4. true

  • multiSet void multiSet(Map<? extends K, ? extends V> m);
    为多个键分别设置它们的值
  1. 使用:Map<String,String> maps = new HashMap<String, String>();

  2. maps.put("multi1","multi1");

  3. maps.put("multi2","multi2");

  4. maps.put("multi3","multi3");

  5. template.opsForValue().multiSet(maps);

  6. List<String> keys = new ArrayList<String>();

  7. keys.add("multi1");

  8. keys.add("multi2");

  9. keys.add("multi3");

  10. System.out.println(template.opsForValue().multiGet(keys));

  11. 结果:[multi1, multi2, multi3]

  • multiSetIfAbsent Boolean multiSetIfAbsent(Map<? extends K, ? extends V> m);
    为多个键分别设置它们的值,如果存在则返回false,不存在返回true
  1. 使用:Map<String,String> maps = new HashMap<String, String>();

  2. maps.put("multi11","multi11");

  3. maps.put("multi22","multi22");

  4. maps.put("multi33","multi33");

  5. Map<String,String> maps2 = new HashMap<String, String>();

  6. maps2.put("multi1","multi1");

  7. maps2.put("multi2","multi2");

  8. maps2.put("multi3","multi3");

  9. System.out.println(template.opsForValue().multiSetIfAbsent(maps));

  10. System.out.println(template.opsForValue().multiSetIfAbsent(maps2));

  11. 结果:true

  12. false

  • get V get(Object key);
  1. 使用:template.opsForValue().set("key","hello world");

  2. System.out.println("***************"+template.opsForValue().get("key"));

  3. 结果:***************hello world

  • getAndSet V getAndSet(K key, V value);
    设置键的字符串值并返回其旧值
  1. 使用:template.opsForValue().set("getSetTest","test");

  2. System.out.println(template.opsForValue().getAndSet("getSetTest","test2"));

  3. 结果:test

  • multiGet List<V> multiGet(Collection<K> keys);
    为多个键分别取出它们的值
  1. 使用:Map<String,String> maps = new HashMap<String, String>();

  2. maps.put("multi1","multi1");

  3. maps.put("multi2","multi2");

  4. maps.put("multi3","multi3");

  5. template.opsForValue().multiSet(maps);

  6. List<String> keys = new ArrayList<String>();

  7. keys.add("multi1");

  8. keys.add("multi2");

  9. keys.add("multi3");

  10. System.out.println(template.opsForValue().multiGet(keys));

  11. 结果:[multi1, multi2, multi3]

  • increment Long increment(K key, long delta);
    支持整数
  1. 使用:template.opsForValue().increment("increlong",1);

  2. System.out.println("***************"+template.opsForValue().get("increlong"));

  3. 结果:***************1

  • increment Double increment(K key, double delta);
    也支持浮点数
  1. 使用:template.opsForValue().increment("increlong",1.2);

  2. System.out.println("***************"+template.opsForValue().get("increlong"));

  3. 结果:***************2.2

  • append Integer append(K key, String value);
    如果key已经存在并且是一个字符串,则该命令将该值追加到字符串的末尾。如果键不存在,则它被创建并设置为空字符串,因此APPEND在这种特殊情况下将类似于SET。
  1. 使用:template.opsForValue().append("appendTest","Hello");

  2. System.out.println(template.opsForValue().get("appendTest"));

  3. template.opsForValue().append("appendTest","world");

  4. System.out.println(template.opsForValue().get("appendTest"));

  5. 结果:Hello

  6. Helloworld

  • get String get(K key, long start, long end);
    截取key所对应的value字符串
  1. 使用:appendTest对应的value为Helloworld

  2. System.out.println("*********"+template.opsForValue().get("appendTest",0,5));

  3. 结果:*********Hellow

  4. 使用:System.out.println("*********"+template.opsForValue().get("appendTest",0,-1));

  5. 结果:*********Helloworld

  6. 使用:System.out.println("*********"+template.opsForValue().get("appendTest",-3,-1));

  7. 结果:*********rld

  • size Long size(K key);
    返回key所对应的value值得长度
  1. 使用:template.opsForValue().set("key","hello world");

  2. System.out.println("***************"+template.opsForValue().size("key"));

  3. 结果:***************11

  • setBit Boolean setBit(K key, long offset, boolean value);
    对 key 所储存的字符串值,设置或清除指定偏移量上的位(bit)
    key键对应的值value对应的ascii码,在offset的位置(从左向右数)变为value
  1. 使用:template.opsForValue().set("bitTest","a");

  2. // 'a' 的ASCII码是 97。转换为二进制是:01100001

  3. // 'b' 的ASCII码是 98 转换为二进制是:01100010

  4. // 'c' 的ASCII码是 99 转换为二进制是:01100011

  5. //因为二进制只有0和1,在setbit中true为1,false为0,因此我要变为'b'的话第六位设置为1,第七位设置为0

  6. template.opsForValue().setBit("bitTest",6, true);

  7. template.opsForValue().setBit("bitTest",7, false);

  8. System.out.println(template.opsForValue().get("bitTest"));

  9. 结果:b

  • getBit Boolean getBit(K key, long offset);
    获取键对应值的ascii码的在offset处位值
  1. 使用:System.out.println(template.opsForValue().getBit("bitTest",7));

  2. 结果:false

Redis的List数据结构

这边我们把RedisTemplate序列化方式改回之前的

  1. Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);

  2. ObjectMapper om = new ObjectMapper();

  3. om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);

  4. om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);

  5. jackson2JsonRedisSerializer.setObjectMapper(om);

  6. RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();

  7. template.setKeySerializer(jackson2JsonRedisSerializer);

  8. template.setValueSerializer(jackson2JsonRedisSerializer);

  9. template.setHashKeySerializer(jackson2JsonRedisSerializer);

  10. template.setHashValueSerializer(jackson2JsonRedisSerializer);

public interface ListOperations<K,V>
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)
ListOperations专门操作list列表:

  • List<V> range(K key, long start, long end);
    返回存储在键中的列表的指定元素。偏移开始和停止是基于零的索引,其中0是列表的第一个元素(列表的头部),1是下一个元素
  1. 使用:System.out.println(template.opsForList().range("list",0,-1));

  2. 结果:[c#, c++, python, java, c#, c#]

  • void trim(K key, long start, long end);
    修剪现有列表,使其只包含指定的指定范围的元素,起始和停止都是基于0的索引
  1. 使用:System.out.println(template.opsForList().range("list",0,-1));

  2. template.opsForList().trim("list",1,-1);//裁剪第一个元素

  3. System.out.println(template.opsForList().range("list",0,-1));

  4. 结果:[c#, c++, python, java, c#, c#]

  5. [c++, python, java, c#, c#]

  • Long size(K key);
    返回存储在键中的列表的长度。如果键不存在,则将其解释为空列表,并返回0。当key存储的值不是列表时返回错误。
  1. 使用:System.out.println(template.opsForList().size("list"));

  2. 结果:6

  • Long leftPush(K key, V value);
    将所有指定的值插入存储在键的列表的头部。如果键不存在,则在执行推送操作之前将其创建为空列表。(从左边插入)
  1. 使用:template.opsForList().leftPush("list","java");

  2. template.opsForList().leftPush("list","python");

  3. template.opsForList().leftPush("list","c++");

  4. 结果:返回的结果为推送操作后的列表的长度

  5. 1

  6. 2

  7. 3

  • Long leftPushAll(K key, V... values);
    批量把一个数组插入到列表中
  1. 使用:String[] stringarrays = new String[]{"1","2","3"};

  2. template.opsForList().leftPushAll("listarray",stringarrays);

  3. System.out.println(template.opsForList().range("listarray",0,-1));

  4. 结果:[3, 2, 1]

  • Long leftPushAll(K key, Collection<V> values);
    批量把一个集合插入到列表中
  1. 使用:List<Object> strings = new ArrayList<Object>();

  2. strings.add("1");

  3. strings.add("2");

  4. strings.add("3");

  5. template.opsForList().leftPushAll("listcollection4", strings);

  6. System.out.println(template.opsForList().range("listcollection4",0,-1));

  7. 结果:[3, 2, 1]

  • Long leftPushIfPresent(K key, V value);
    只有存在key对应的列表才能将这个value值插入到key所对应的列表中
  1. 使用:System.out.println(template.opsForList().leftPushIfPresent("leftPushIfPresent","aa"));

  2. System.out.println(template.opsForList().leftPushIfPresent("leftPushIfPresent","bb"));

  3. ==========分割线===========

  4. System.out.println(template.opsForList().leftPush("leftPushIfPresent","aa"));

  5. System.out.println(template.opsForList().leftPushIfPresent("leftPushIfPresent","bb"));

  6. 结果:

  7. 0

  8. 0

  9. ==========分割线===========

  10. 1

  11. 2

  • Long leftPush(K key, V pivot, V value);
    把value值放到key对应列表中pivot值的左面,如果pivot值存在的话
  1. 使用:template.opsForList().leftPush("list","java","oc");

  2. System.out.print(template.opsForList().range("list",0,-1));

  3. 结果:[c++, python, oc, java, c#, c#]

  • Long rightPush(K key, V value);
    将所有指定的值插入存储在键的列表的头部。如果键不存在,则在执行推送操作之前将其创建为空列表。(从右边插入)
  1. 使用:template.opsForList().rightPush("listRight","java");

  2. template.opsForList().rightPush("listRight","python");

  3. template.opsForList().rightPush("listRight","c++");

  4. 结果:

  5. 1

  6. 2

  7. 3

  • Long rightPushAll(K key, V... values);
  1. 使用:String[] stringarrays = new String[]{"1","2","3"};

  2. template.opsForList().rightPushAll("listarrayright",stringarrays);

  3. System.out.println(template.opsForList().range("listarrayright",0,-1));

  4. 结果:[1, 2, 3]

  • Long rightPushAll(K key, Collection<V> values);
  1. 使用:List<Object> strings = new ArrayList<Object>();

  2. strings.add("1");

  3. strings.add("2");

  4. strings.add("3");

  5. template.opsForList().rightPushAll("listcollectionright", strings);

  6. System.out.println(template.opsForList().range("listcollectionright",0,-1));

  7. 结果:[1, 2, 3]

  • Long rightPushIfPresent(K key, V value);
    只有存在key对应的列表才能将这个value值插入到key所对应的列表中
  1. 使用:System.out.println(template.opsForList().rightPushIfPresent("rightPushIfPresent","aa"));

  2. System.out.println(template.opsForList().rightPushIfPresent("rightPushIfPresent","bb"));

  3. System.out.println("==========分割线===========");

  4. System.out.println(template.opsForList().rightPush("rightPushIfPresent","aa"));

  5. System.out.println(template.opsForList().rightPushIfPresent("rightPushIfPresent","bb"));

  6. 结果:0

  7. 0

  8. ==========分割线===========

  9. 1

  10. 2

  • Long rightPush(K key, V pivot, V value);
    把value值放到key对应列表中pivot值的右面,如果pivot值存在的话
  1. 使用:System.out.println(template.opsForList().range("listRight",0,-1));

  2. template.opsForList().rightPush("listRight","python","oc");

  3. System.out.println(template.opsForList().range("listRight",0,-1));

  4. 结果:[java, python, c++]

  5. [java, python, oc, c++]

  • void set(K key, long index, V value);
    在列表中index的位置设置value值
  1. 使用:System.out.println(template.opsForList().range("listRight",0,-1));

  2. template.opsForList().set("listRight",1,"setValue");

  3. System.out.println(template.opsForList().range("listRight",0,-1));

  4. 结果:[java, python, oc, c++]

  5. [java, setValue, oc, c++]

  • Long remove(K key, long count, Object value);
    从存储在键中的列表中删除等于值的元素的第一个计数事件。
    计数参数以下列方式影响操作:
    count> 0:删除等于从头到尾移动的值的元素。
    count <0:删除等于从尾到头移动的值的元素。
    count = 0:删除等于value的所有元素。
  1. 使用:System.out.println(template.opsForList().range("listRight",0,-1));

  2. template.opsForList().remove("listRight",1,"setValue");//将删除列表中存储的列表中第一次次出现的“setValue”。

  3. System.out.println(template.opsForList().range("listRight",0,-1));

  4. 结果:[java, setValue, oc, c++]

  5. [java, oc, c++]

  • V index(K key, long index);
    根据下表获取列表中的值,下标是从0开始的
  1. 使用:System.out.println(template.opsForList().range("listRight",0,-1));

  2. System.out.println(template.opsForList().index("listRight",2));

  3. 结果:[java, oc, c++]

  4. c++

  • V leftPop(K key);
    弹出最左边的元素,弹出之后该值在列表中将不复存在
  1. 使用:System.out.println(template.opsForList().range("list",0,-1));

  2. System.out.println(template.opsForList().leftPop("list"));

  3. System.out.println(template.opsForList().range("list",0,-1));

  4. 结果:

  5. [c++, python, oc, java, c#, c#]

  6. c++

  7. [python, oc, java, c#, c#]

  • V leftPop(K key, long timeout, TimeUnit unit);
    移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
使用:用法与 leftPop(K key);一样
  • V rightPop(K key);
    弹出最右边的元素,弹出之后该值在列表中将不复存在
  1. 使用: System.out.println(template.opsForList().range("list",0,-1));

  2. System.out.println(template.opsForList().rightPop("list"));

  3. System.out.println(template.opsForList().range("list",0,-1));

  4. 结果:[python, oc, java, c#, c#]

  5. c#

  6. [python, oc, java, c#]

  • V rightPop(K key, long timeout, TimeUnit unit);
    移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
使用:用法与 rightPop(K key);一样
  • V rightPopAndLeftPush(K sourceKey, K destinationKey);
    用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。
  1. 使用:System.out.println(template.opsForList().range("list",0,-1));

  2. template.opsForList().rightPopAndLeftPush("list","rightPopAndLeftPush");

  3. System.out.println(template.opsForList().range("list",0,-1));

  4. System.out.println(template.opsForList().range("rightPopAndLeftPush",0,-1));

  5. 结果:[oc, java,c#]

  6. [oc, java]

  7. [c#]

  • V rightPopAndLeftPush(K sourceKey, K destinationKey, long timeout, TimeUnit unit);
    用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
使用:用法与rightPopAndLeftPush(K sourceKey, K destinationKey)一样

Redis的Hash数据机构

Redis的散列可以让用户将多个键值对存储到一个Redis键里面。
public interface HashOperations<H,HK,HV>
HashOperations提供一系列方法操作hash:

  1. 初始数据:

  2. //template.opsForHash().put("redisHash","name","tom");

  3. //template.opsForHash().put("redisHash","age",26);

  4. //template.opsForHash().put("redisHash","class","6");

  5. //Map<String,Object> testMap = new HashMap();

  6. //testMap.put("name","jack");

  7. //testMap.put("age",27);

  8. //testMap.put("class","1");

  9. //template.opsForHash().putAll("redisHash1",testMap);

  • Long delete(H key, Object... hashKeys);
    删除给定的哈希hashKeys
  1. 使用:System.out.println(template.opsForHash().delete("redisHash","name"));

  2. System.out.println(template.opsForHash().entries("redisHash"));

  3. 结果:1

  4. {class=6, age=28.1}

  • Boolean hasKey(H key, Object hashKey);
    确定哈希hashKey是否存在
  1. 使用:System.out.println(template.opsForHash().hasKey("redisHash","age"));

  2. System.out.println(template.opsForHash().hasKey("redisHash","ttt"));

  3. 结果:true

  4. false

  • HV get(H key, Object hashKey);
    从键中的哈希获取给定hashKey的值
  1. 使用:System.out.println(template.opsForHash().get("redisHash","age"));

  2. 结果:26

  • List<HV> multiGet(H key, Collection<HK> hashKeys);
    从哈希中获取给定hashKey的值
  1. 使用:List<Object> kes = new ArrayList<Object>();

  2. kes.add("name");

  3. kes.add("age");

  4. System.out.println(template.opsForHash().multiGet("redisHash",kes));

  5. 结果:[jack, 28.1]

  • Long increment(H key, HK hashKey, long delta);
    通过给定的delta增加散列hashKey的值(整型)
  1. 使用:System.out.println(template.opsForHash().get("redisHash","age"));

  2. System.out.println(template.opsForHash().increment("redisHash","age",1));

  3. 结果:26

  4. 27

  • Double increment(H key, HK hashKey, double delta);
    通过给定的delta增加散列hashKey的值(浮点数)
  1. 使用:System.out.println(template.opsForHash().get("redisHash","age"));

  2. System.out.println(template.opsForHash().increment("redisHash","age",1.1));

  3. 结果:27

  4. 28.1

  • Set<HK> keys(H key);
    获取key所对应的散列表的key
  1. 使用:System.out.println(template.opsForHash().keys("redisHash1"));

  2. //redisHash1所对应的散列表为{class=1, name=jack, age=27}

  3. 结果:[name, class, age]

  • Long size(H key);
    获取key所对应的散列表的大小个数
  1. 使用:System.out.println(template.opsForHash().size("redisHash1"));

  2. //redisHash1所对应的散列表为{class=1, name=jack, age=27}

  3. 结果:3

  • void putAll(H key, Map<? extends HK, ? extends HV> m);
    使用m中提供的多个散列字段设置到key对应的散列表中
  1. 使用:Map<String,Object> testMap = new HashMap();

  2. testMap.put("name","jack");

  3. testMap.put("age",27);

  4. testMap.put("class","1");

  5. template.opsForHash().putAll("redisHash1",testMap);

  6. System.out.println(template.opsForHash().entries("redisHash1"));

  7. 结果:{class=1, name=jack, age=27}

  • void put(H key, HK hashKey, HV value);
    设置散列hashKey的值
  1. 使用:template.opsForHash().put("redisHash","name","tom");

  2. template.opsForHash().put("redisHash","age",26);

  3. template.opsForHash().put("redisHash","class","6");

  4. System.out.println(template.opsForHash().entries("redisHash"));

  5. 结果:{age=26, class=6, name=tom}

  • Boolean putIfAbsent(H key, HK hashKey, HV value);
    仅当hashKey不存在时才设置散列hashKey的值。
  1. 使用:System.out.println(template.opsForHash().putIfAbsent("redisHash","age",30));

  2. System.out.println(template.opsForHash().putIfAbsent("redisHash","kkk","kkk"));

  3. 结果:false

  4. true

  • List<HV> values(H key);
    获取整个哈希存储的值根据密钥
  1. 使用:System.out.println(template.opsForHash().values("redisHash"));

  2. 结果:[tom, 26, 6]

  • Map<HK, HV> entries(H key);
    获取整个哈希存储根据密钥
  1. 使用:System.out.println(template.opsForHash().entries("redisHash"));

  2. 结果:{age=26, class=6, name=tom}

  • Cursor<Map.Entry<HK, HV>> scan(H key, ScanOptions options);
    使用Cursor在key的hash中迭代,相当于迭代器。
  1. 使用:Cursor<Map.Entry<Object, Object>> curosr = template.opsForHash().scan("redisHash", ScanOptions.ScanOptions.NONE);

  2. while(curosr.hasNext()){

  3. Map.Entry<Object, Object> entry = curosr.next();

  4. System.out.println(entry.getKey()+":"+entry.getValue());

  5. }

  6. 结果:age:28.1

  7. class:6

  8. kkk:kkk

Redis的Set数据结构

Redis的Set是string类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
public interface SetOperations<K,V>
SetOperations提供了对无序集合的一系列操作:

  • Long add(K key, V... values);
    无序集合中添加元素,返回添加个数
    也可以直接在add里面添加多个值 如:template.opsForSet().add("setTest","aaa","bbb")
  1. 使用:String[] strarrays = new String[]{"strarr1","sgtarr2"};

  2. System.out.println(template.opsForSet().add("setTest", strarrays));

  3. 结果:2

  • Long remove(K key, Object... values);
    移除集合中一个或多个成员
  1. 使用:String[] strarrays = new String[]{"strarr1","sgtarr2"};

  2. System.out.println(template.opsForSet().remove("setTest",strarrays));

  3. 结果:2

  • V pop(K key);
    移除并返回集合中的一个随机元素
  1. 使用:System.out.println(template.opsForSet().pop("setTest"));

  2. System.out.println(template.opsForSet().members("setTest"));

  3. 结果:bbb

  4. [aaa, ccc]

  • Boolean move(K key, V value, K destKey);
    将 member 元素从 source 集合移动到 destination 集合
  1. 使用:template.opsForSet().move("setTest","aaa","setTest2");

  2. System.out.println(template.opsForSet().members("setTest"));

  3. System.out.println(template.opsForSet().members("setTest2"));

  4. 结果:[ccc]

  5. [aaa]

  • Long size(K key);
    无序集合的大小长度
  1. 使用:System.out.println(template.opsForSet().size("setTest"));

  2. 结果:1

  • Boolean isMember(K key, Object o);
    判断 member 元素是否是集合 key 的成员
  1. 使用:System.out.println(template.opsForSet().isMember("setTest","ccc"));

  2. System.out.println(template.opsForSet().isMember("setTest","asd"));

  3. 结果:true

  4. false

  • Set<V> intersect(K key, K otherKey);
    key对应的无序集合与otherKey对应的无序集合求交集
  1. 使用:System.out.println(template.opsForSet().members("setTest"));

  2. System.out.println(template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().intersect("setTest","setTest2"));

  4. 结果:[aaa, ccc]

  5. [aaa]

  6. [aaa]

  • Set<V> intersect(K key, Collection<K> otherKeys);
    key对应的无序集合与多个otherKey对应的无序集合求交集
  1. 使用:System.out.println(template.opsForSet().members("setTest"));

  2. System.out.println(template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().members("setTest3"));

  4. List<String> strlist = new ArrayList<String>();

  5. strlist.add("setTest2");

  6. strlist.add("setTest3");

  7. System.out.println(template.opsForSet().intersect("setTest",strlist));

  8. 结果:[aaa, ccc]

  9. [aaa]

  10. [ccc, aaa]

  11. [aaa]

  • Long intersectAndStore(K key, K otherKey, K destKey);
    key无序集合与otherkey无序集合的交集存储到destKey无序集合中
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().intersectAndStore("setTest","setTest2","destKey1"));

  4. System.out.println(template.opsForSet().members("destKey1"));

  5. 结果:setTest:[ddd, bbb, aaa, ccc]

  6. setTest2:[ccc, aaa]

  7. 2

  8. [aaa, ccc]

  • Long intersectAndStore(K key, Collection<K> otherKeys, K destKey);
    key对应的无序集合与多个otherKey对应的无序集合求交集存储到destKey无序集合中
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println("setTest3:" + template.opsForSet().members("setTest3"));

  4. List<String> strlist = new ArrayList<String>();

  5. strlist.add("setTest2");

  6. strlist.add("setTest3");

  7. System.out.println(template.opsForSet().intersectAndStore("setTest",strlist,"destKey2"));

  8. System.out.println(template.opsForSet().members("destKey2"));

  9. 结果:setTest:[ddd, bbb, aaa, ccc]

  10. setTest2:[ccc, aaa]

  11. setTest3:[ccc, aaa]

  12. 2

  13. [aaa, ccc]

  • Set<V> union(K key, K otherKey);
    key无序集合与otherKey无序集合的并集
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().union("setTest","setTest2"));

  4. 结果:setTest:[ddd, bbb, aaa, ccc]

  5. setTest2:[ccc, aaa]

  6. [ccc, aaa, ddd, bbb]

  • Set<V> union(K key, Collection<K> otherKeys);
    key无序集合与多个otherKey无序集合的并集
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println("setTest3:" + template.opsForSet().members("setTest3"));

  4. List<String> strlist = new ArrayList<String>();

  5. strlist.add("setTest2");

  6. strlist.add("setTest3");

  7. System.out.println(template.opsForSet().union("setTest",strlist));

  8. 结果:setTest:[ddd, bbb, aaa, ccc]

  9. setTest2:[ccc, aaa]

  10. setTest3:[xxx, ccc, aaa]

  11. [ddd, xxx, bbb, aaa, ccc]

  • Long unionAndStore(K key, K otherKey, K destKey);
    key无序集合与otherkey无序集合的并集存储到destKey无序集合中
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().unionAndStore("setTest","setTest2","unionAndStoreTest1"));

  4. System.out.println("unionAndStoreTest1:" + template.opsForSet().members("unionAndStoreTest1"));

  5. 结果:setTest:[ddd, bbb, aaa, ccc]

  6. setTest2:[ccc, aaa]

  7. 4

  8. unionAndStoreTest1:[ccc, aaa, ddd, bbb]

  • Long unionAndStore(K key, Collection<K> otherKeys, K destKey);
    key无序集合与多个otherkey无序集合的并集存储到destKey无序集合中
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println("setTest3:" + template.opsForSet().members("setTest3"));

  4. List<String> strlist = new ArrayList<String>();

  5. strlist.add("setTest2");

  6. strlist.add("setTest3");

  7. System.out.println(template.opsForSet().unionAndStore("setTest",strlist,"unionAndStoreTest2"));

  8. System.out.println("unionAndStoreTest2:" + template.opsForSet().members("unionAndStoreTest2"));

  9. 结果:setTest:[ddd, bbb, aaa, ccc]

  10. setTest2:[ccc, aaa]

  11. setTest3:[xxx, ccc, aaa]

  12. 5

  13. unionAndStoreTest2:[ddd, xxx, bbb, aaa, ccc]

  • Set<V> difference(K key, K otherKey);
    key无序集合与otherKey无序集合的差集
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().difference("setTest","setTest2"));

  4. 结果:setTest:[ddd, bbb, aaa, ccc]

  5. setTest2:[ccc, aaa]

  6. [bbb, ddd]

  • Set<V> difference(K key, Collection<K> otherKeys);
    key无序集合与多个otherKey无序集合的差集
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println("setTest3:" + template.opsForSet().members("setTest3"));

  4. List<String> strlist = new ArrayList<String>();

  5. strlist.add("setTest2");

  6. strlist.add("setTest3");

  7. System.out.println(template.opsForSet().difference("setTest",strlist));

  8. 结果:setTest:[ddd, bbb, aaa, ccc]

  9. setTest2:[ccc, aaa]

  10. setTest3:[xxx, ccc, aaa]

  11. [bbb, ddd]

  • Long differenceAndStore(K key, K otherKey, K destKey);
    key无序集合与otherkey无序集合的差集存储到destKey无序集合中
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println(template.opsForSet().differenceAndStore("setTest","setTest2","differenceAndStore1"));

  4. System.out.println("differenceAndStore1:" + template.opsForSet().members("differenceAndStore1"));

  5. 结果:setTest:[ddd, bbb, aaa, ccc]

  6. setTest2:[ccc, aaa]

  7. 2

  8. differenceAndStore1:[bbb, ddd]

  • Long differenceAndStore(K key, Collection<K> otherKeys, K destKey);
    key无序集合与多个otherkey无序集合的差集存储到destKey无序集合中
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTest2:" + template.opsForSet().members("setTest2"));

  3. System.out.println("setTest3:" + template.opsForSet().members("setTest3"));

  4. List<String> strlist = new ArrayList<String>();

  5. strlist.add("setTest2");

  6. strlist.add("setTest3");

  7. System.out.println(template.opsForSet().differenceAndStore("setTest",strlist,"differenceAndStore2"));

  8. System.out.println("differenceAndStore2:" + template.opsForSet().members("differenceAndStore2"));

  9. 结果:setTest:[ddd, bbb, aaa, ccc]

  10. setTest2:[ccc, aaa]

  11. setTest3:[xxx, ccc, aaa]

  12. 2

  13. differenceAndStore2:[bbb, ddd]

  • Set<V> members(K key);
    返回集合中的所有成员
  1. 使用:System.out.println(template.opsForSet().members("setTest"));

  2. 结果:[ddd, bbb, aaa, ccc]

  • V randomMember(K key);
    随机获取key无序集合中的一个元素
  1. 使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));

  2. System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));

  3. System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));

  4. System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));

  5. System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));

  6. 结果:setTest:[ddd, bbb, aaa, ccc]

  7. setTestrandomMember:aaa

  8. setTestrandomMember:bbb

  9. setTestrandomMember:aaa

  10. setTestrandomMember:ddd

  • Set<V> distinctRandomMembers(K key, long count);
    获取多个key无序集合中的元素(去重),count表示个数
  1. 使用:System.out.println("randomMembers:" + template.opsForSet().distinctRandomMembers("setTest",5));

  2. 结果:randomMembers:[aaa, bbb, ddd, ccc]

  • List<V> randomMembers(K key, long count);
    获取多个key无序集合中的元素,count表示个数
  1. 使用:System.out.println("randomMembers:" + template.opsForSet().randomMembers("setTest",5));

  2. 结果:randomMembers:[ccc, ddd, ddd, ddd, aaa]

  • Cursor<V> scan(K key, ScanOptions options);
    遍历set
  1. 使用: Cursor<Object> curosr = template.opsForSet().scan("setTest", ScanOptions.NONE);

  2. while(curosr.hasNext()){

  3. System.out.println(curosr.next());

  4. }

  5. 结果:ddd

  6. bbb

  7. aaa

  8. ccc

Redis的ZSet数据结构

Redis 有序集合和无序集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
public interface ZSetOperations<K,V>
ZSetOperations提供了一系列方法对有序集合进行操作:

  • Boolean add(K key, V value, double score);
    新增一个有序集合,存在的话为false,不存在的话为true
  1. 使用:System.out.println(template.opsForZSet().add("zset1","zset-1",1.0));

  2. 结果:true

  • Long add(K key, Set<TypedTuple<V>> tuples);
    新增一个有序集合
  1. 使用:ZSetOperations.TypedTuple<Object> objectTypedTuple1 = new DefaultTypedTuple<Object>("zset-5",9.6);

  2. ZSetOperations.TypedTuple<Object> objectTypedTuple2 = new DefaultTypedTuple<Object>("zset-6",9.9);

  3. Set<ZSetOperations.TypedTuple<Object>> tuples = new HashSet<ZSetOperations.TypedTuple<Object>>();

  4. tuples.add(objectTypedTuple1);

  5. tuples.add(objectTypedTuple2);

  6. System.out.println(template.opsForZSet().add("zset1",tuples));

  7. System.out.println(template.opsForZSet().range("zset1",0,-1));

  8. 结果:[zset-1, zset-2, zset-3, zset-4, zset-5, zset-6]

  • Long remove(K key, Object... values);
    从有序集合中移除一个或者多个元素
  1. 使用:System.out.println(template.opsForZSet().range("zset1",0,-1));

  2. System.out.println(template.opsForZSet().remove("zset1","zset-6"));

  3. System.out.println(template.opsForZSet().range("zset1",0,-1));

  4. 结果:[zset-1, zset-2, zset-3, zset-4, zset-5, zset-6]

  5. 1

  6. [zset-1, zset-2, zset-3, zset-4, zset-5]

  • Double incrementScore(K key, V value, double delta);
    增加元素的score值,并返回增加后的值
  1. 使用:System.out.println(template.opsForZSet().incrementScore("zset1","zset-1",1.1)); //原为1.1

  2. 结果:2.2

  • Long rank(K key, Object o);
    返回有序集中指定成员的排名,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:System.out.println(template.opsForZSet().range("zset1",0,-1));

  2. System.out.println(template.opsForZSet().rank("zset1","zset-2"));

  3. 结果:[zset-2, zset-1, zset-3, zset-4, zset-5]

  4. 0 //表明排名第一

  • Long reverseRank(K key, Object o);
    返回有序集中指定成员的排名,其中有序集成员按分数值递减(从大到小)顺序排列
  1. 使用:System.out.println(template.opsForZSet().range("zset1",0,-1));

  2. System.out.println(template.opsForZSet().reverseRank("zset1","zset-2"));

  3. 结果:[zset-2, zset-1, zset-3, zset-4, zset-5]

  4. 4 //递减之后排到第五位去了

  • Set<V> range(K key, long start, long end);
    通过索引区间返回有序集合成指定区间内的成员,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:System.out.println(template.opsForZSet().range("zset1",0,-1));

  2. 结果:[zset-2, zset-1, zset-3, zset-4, zset-5]

  • Set<TypedTuple<V>> rangeWithScores(K key, long start, long end);
    通过索引区间返回有序集合成指定区间内的成员对象,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("zset1",0,-1);

  2. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  3. while (iterator.hasNext())

  4. {

  5. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  6. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  7. }

  8. 结果:value:zset-2score:1.2

  9. value:zset-1score:2.2

  10. value:zset-3score:2.3

  11. value:zset-4score:6.6

  12. value:zset-5score:9.6

  • Set<V> rangeByScore(K key, double min, double max);
    通过分数返回有序集合指定区间内的成员,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:System.out.println(template.opsForZSet().rangeByScore("zset1",0,5));

  2. 结果:[zset-2, zset-1, zset-3]

  • Set<TypedTuple<V>> rangeByScoreWithScores(K key, double min, double max);
    通过分数返回有序集合指定区间内的成员对象,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeByScoreWithScores("zset1",0,5);

  2. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  3. while (iterator.hasNext())

  4. {

  5. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  6. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  7. }

  8. 结果:value:zset-2score:1.2

  9. value:zset-1score:2.2

  10. value:zset-3score:2.3

  • Set<V> rangeByScore(K key, double min, double max, long offset, long count);
    通过分数返回有序集合指定区间内的成员,并在索引范围内,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用: System.out.println(template.opsForZSet().rangeByScore("zset1",0,5));

  2. System.out.println(template.opsForZSet().rangeByScore("zset1",0,5,1,2));

  3. 结果:[zset-2, zset-1, zset-3]

  4. [zset-1, zset-3]

  • Set<TypedTuple<V>> rangeByScoreWithScores(K key, double min, double max, long offset, long count);
    通过分数返回有序集合指定区间内的成员对象,并在索引范围内,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeByScoreWithScores("zset1",0,5,1,2);

  2. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  3. while (iterator.hasNext())

  4. {

  5. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  6. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  7. }

  8. 结果:value:zset-1score:2.2

  9. value:zset-3score:2.3

  • Set<V> reverseRange(K key, long start, long end);
    通过索引区间返回有序集合成指定区间内的成员,其中有序集成员按分数值递减(从大到小)顺序排列
  1. 使用:System.out.println(template.opsForZSet().reverseRange("zset1",0,-1));

  2. 结果:[zset-5, zset-4, zset-3, zset-1, zset-2]

  • Set<TypedTuple<V>> reverseRangeWithScores(K key, long start, long end);
    通过索引区间返回有序集合成指定区间内的成员对象,其中有序集成员按分数值递减(从大到小)顺序排列
  1. 使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().reverseRangeWithScores("zset1",0,-1);

  2. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  3. while (iterator.hasNext())

  4. {

  5. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  6. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  7. }

  8. 结果:value:zset-5score:9.6

  9. value:zset-4score:6.6

  10. value:zset-3score:2.3

  11. value:zset-1score:2.2

  12. value:zset-2score:1.2

  • Set<V> reverseRangeByScore(K key, double min, double max);
使用:与rangeByScore调用方法一样,其中有序集成员按分数值递减(从大到小)顺序排列
  • Set<TypedTuple<V>> reverseRangeByScoreWithScores(K key, double min, double max);
使用:与rangeByScoreWithScores调用方法一样,其中有序集成员按分数值递减(从大到小)顺序排列
  • Set<V> reverseRangeByScore(K key, double min, double max, long offset, long count);
使用:与rangeByScore调用方法一样,其中有序集成员按分数值递减(从大到小)顺序排列
  • Set<TypedTuple<V>> reverseRangeByScoreWithScores(K key, double min, double max, long offset, long count);
使用:与rangeByScoreWithScores调用方法一样,其中有序集成员按分数值递减(从大到小)顺序排列
  • Long count(K key, double min, double max);
    通过分数返回有序集合指定区间内的成员个数
  1. 使用:System.out.println(template.opsForZSet().rangeByScore("zset1",0,5));

  2. System.out.println(template.opsForZSet().count("zset1",0,5));

  3. 结果:[zset-2, zset-1, zset-3]

  4. 3

  • Long size(K key);
    获取有序集合的成员数,内部调用的就是zCard方法
  1. 使用:System.out.println(template.opsForZSet().size("zset1"));

  2. 结果:6

  • Long zCard(K key);
    获取有序集合的成员数
  1. 使用:System.out.println(template.opsForZSet().zCard("zset1"));

  2. 结果:6

  • Double score(K key, Object o);
    获取指定成员的score值
  1. 使用:System.out.println(template.opsForZSet().score("zset1","zset-1"));

  2. 结果:2.2

  • Long removeRange(K key, long start, long end);
    移除指定索引位置的成员,其中有序集成员按分数值递增(从小到大)顺序排列
  1. 使用:System.out.println(template.opsForZSet().range("zset2",0,-1));

  2. System.out.println(template.opsForZSet().removeRange("zset2",1,2));

  3. System.out.println(template.opsForZSet().range("zset2",0,-1));

  4. 结果:[zset-1, zset-2, zset-3, zset-4]

  5. 2

  6. [zset-1, zset-4]

  • Long removeRangeByScore(K key, double min, double max);
    根据指定的score值得范围来移除成员
  1. 使用://System.out.println(template.opsForZSet().add("zset2","zset-1",1.1));

  2. //System.out.println(template.opsForZSet().add("zset2","zset-2",1.2));

  3. //System.out.println(template.opsForZSet().add("zset2","zset-3",2.3));

  4. //System.out.println(template.opsForZSet().add("zset2","zset-4",6.6));

  5. System.out.println(template.opsForZSet().range("zset2",0,-1));

  6. System.out.println(template.opsForZSet().removeRangeByScore("zset2",2,3));

  7. System.out.println(template.opsForZSet().range("zset2",0,-1));

  8. 结果:[zset-1, zset-2, zset-3,zset-4]

  9. 1

  10. [zset-1, zset-2, zset-4]

  • Long unionAndStore(K key, K otherKey, K destKey);
    计算给定的一个有序集的并集,并存储在新的 destKey中,key相同的话会把score值相加
  1. 使用:System.out.println(template.opsForZSet().add("zzset1","zset-1",1.0));

  2. System.out.println(template.opsForZSet().add("zzset1","zset-2",2.0));

  3. System.out.println(template.opsForZSet().add("zzset1","zset-3",3.0));

  4. System.out.println(template.opsForZSet().add("zzset1","zset-4",6.0));

  5. System.out.println(template.opsForZSet().add("zzset2","zset-1",1.0));

  6. System.out.println(template.opsForZSet().add("zzset2","zset-2",2.0));

  7. System.out.println(template.opsForZSet().add("zzset2","zset-3",3.0));

  8. System.out.println(template.opsForZSet().add("zzset2","zset-4",6.0));

  9. System.out.println(template.opsForZSet().add("zzset2","zset-5",7.0));

  10. System.out.println(template.opsForZSet().unionAndStore("zzset1","zzset2","destZset11"));

  11. Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset11",0,-1);

  12. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  13. while (iterator.hasNext())

  14. {

  15. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  16. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  17. }

  18. 结果:value:zset-1score:2.0

  19. value:zset-2score:4.0

  20. value:zset-3score:6.0

  21. value:zset-5score:7.0

  22. value:zset-4score:12.0

  • Long unionAndStore(K key, Collection<K> otherKeys, K destKey);
    计算给定的多个有序集的并集,并存储在新的 destKey中
  1. 使用://System.out.println(template.opsForZSet().add("zzset1","zset-1",1.0));

  2. //System.out.println(template.opsForZSet().add("zzset1","zset-2",2.0));

  3. //System.out.println(template.opsForZSet().add("zzset1","zset-3",3.0));

  4. //System.out.println(template.opsForZSet().add("zzset1","zset-4",6.0));

  5. //

  6. //System.out.println(template.opsForZSet().add("zzset2","zset-1",1.0));

  7. //System.out.println(template.opsForZSet().add("zzset2","zset-2",2.0));

  8. //System.out.println(template.opsForZSet().add("zzset2","zset-3",3.0));

  9. //System.out.println(template.opsForZSet().add("zzset2","zset-4",6.0));

  10. //System.out.println(template.opsForZSet().add("zzset2","zset-5",7.0));

  11. System.out.println(template.opsForZSet().add("zzset3","zset-1",1.0));

  12. System.out.println(template.opsForZSet().add("zzset3","zset-2",2.0));

  13. System.out.println(template.opsForZSet().add("zzset3","zset-3",3.0));

  14. System.out.println(template.opsForZSet().add("zzset3","zset-4",6.0));

  15. System.out.println(template.opsForZSet().add("zzset3","zset-5",7.0));

  16. List<String> stringList = new ArrayList<String>();

  17. stringList.add("zzset2");

  18. stringList.add("zzset3");

  19. System.out.println(template.opsForZSet().unionAndStore("zzset1",stringList,"destZset22"));

  20. Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset22",0,-1);

  21. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  22. while (iterator.hasNext())

  23. {

  24. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  25. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  26. }

  27. 结果:value:zset-1score:3.0

  28. value:zset-2score:6.0

  29. value:zset-3score:9.0

  30. value:zset-5score:14.0

  31. value:zset-4score:18.0

  • Long intersectAndStore(K key, K otherKey, K destKey);
    计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
  1. 使用:System.out.println(template.opsForZSet().intersectAndStore("zzset1","zzset2","destZset33"));

  2. Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset33",0,-1);

  3. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  4. while (iterator.hasNext())

  5. {

  6. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  7. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  8. }

  9. 结果:value:zset-1score:2.0

  10. value:zset-2score:4.0

  11. value:zset-3score:6.0

  12. value:zset-4score:12.0

  • Long intersectAndStore(K key, Collection<K> otherKeys, K destKey);
    计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中
  1. 使用:List<String> stringList = new ArrayList<String>();

  2. stringList.add("zzset2");

  3. stringList.add("zzset3");

  4. System.out.println(template.opsForZSet().intersectAndStore("zzset1",stringList,"destZset44"));

  5. Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset44",0,-1);

  6. Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();

  7. while (iterator.hasNext())

  8. {

  9. ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();

  10. System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());

  11. }

  12. 结果:value:zset-1score:3.0

  13. value:zset-2score:6.0

  14. value:zset-3score:9.0

  15. value:zset-4score:18.0

  • Cursor<TypedTuple<V>> scan(K key, ScanOptions options);
    遍历zset
  1. 使用: Cursor<ZSetOperations.TypedTuple<Object>> cursor = template.opsForZSet().scan("zzset1", ScanOptions.NONE);

  2. while (cursor.hasNext()){

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

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

  5. }

  6. 结果:zset-1:1.0

  7. zset-2:2.0

  8. zset-3:3.0

  9. zset-4:6.0

注:TimeUnit是java.util.concurrent包下面的一个类,表示给定单元粒度的时间段
常用的颗粒度
TimeUnit.DAYS //天
TimeUnit.HOURS //小时
TimeUnit.MINUTES //分钟
TimeUnit.SECONDS //秒
TimeUnit.MILLISECONDS //毫秒

参考文档:Redis实战[约西亚 L.卡尔森 (Josiah L.Carlson)]
Spring官方文档

转:https://www.cnblogs.com/zhuyeshen/p/11433813.html

RedisTemplate与zset redis相关推荐

  1. 【Redis学习】解决使用redisTemplate 时 存入redis 的key 出现 \xac\xed\x00\x05t\x00

    由于使用默认的JdkSerializationRedisSerializer时会导致存入redis中的值出现乱码. 所以要使用非默认的序列化器 在使用redisTemplate时,注入自己定义的bea ...

  2. 利用RedisTemplate报错redis Invalid UTF-32 character 0x6a607661 (above 0x0010ffff) at char #8, byte #35)

    1)可能是redis中存在缓存就会产生相应的冲突,导致请求报错. 解决方法:清除redis中的缓存就可以了 2)在放入里面去加入时间的单位,可能解决问题.

  3. redis缓存路由为空_Springboot使用RedisTemplate优雅地操作redis

    作者:Jantihttp://cnblogs.com/superfj/p/9232482.html 概述 本文内容主要 关于spring-redis 关于redis的key设计 redis的基本数据结 ...

  4. redis3.0 java spring_spring整合redis以及使用RedisTemplate的方法

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

  5. SpringBoot整合Redis 之 StringRedisTemplate、RedisTemplate 基础

    SpringBoot 整合 Redis 环境准备 引入依赖 配置文件 StringRedisTemplate 基本使用 Key 常用操作 String 常用操作 List 常用操作 Set 常用操作 ...

  6. redis ZSet实现排行榜功能

    一.写在前面 最近做完直播的基础功能后,又多了很多相关的需求,其中有一个就是直播间分享榜单的功能,顾名思义就是:分享本直播间并成功拉用户进来的数量做一个排行.比如我分享了这个直播间,别人通过我分享的直 ...

  7. RedisTemplate操作redis五大类型用法详解(springboot整合redis版本)

    1.案例说明 springboot整合redis之后,提供了操作redis的简便方式 通过通用对象redisTemplate方式操作String,Hash,List,Set SortSet五大数据类型 ...

  8. Redis序列化、RedisTemplate序列化方式大解读,介绍Genericjackson2jsonredisserializer序列化器的坑

    前言 上一篇已经介绍了优雅的操作Redis: [小家Spring]Spring Boot中使用RedisTemplate优雅的操作Redis,并且解决RedisTemplate泛型注入的问题.本篇着重 ...

  9. redis zset转set 反序列化失败_7000字 Redis 超详细总结、笔记!建议收藏

    Redis 简介 Redis 是完全开源免费的,遵守 BSD 协议,是一个高性能的 key - value 数据库 Redis 与 其他 key - value 缓存产品有以下三个特点: Redis ...

最新文章

  1. 神马是敏捷?(4)——敏捷不能当饭吃
  2. d3.js 旋转图形_变化莫测的图形推理,你能解出几种?
  3. 3d目标检测_CVPR 2020 |基用于3D目标检测的层级图网络
  4. C++远航之封装篇——默认构造函数、初始化列表、拷贝构造函数
  5. JAVA知识基础(五):深入理解final关键字
  6. linux 内核同步--理解原子操作、自旋锁、信号量(可睡眠)、读写锁、RCU锁、PER_CPU变量、内存屏障
  7. malloc/free 与 new/delete的区别
  8. SpringAs3的一些配置参数
  9. 基于SSM和Vue的旅游网和旅游管理系统
  10. java ojdbc14.jar_ojdbc14_g.jar
  11. Cmder的下载安装及使用
  12. Matlab 三角函数(sin)
  13. fgo服务器维护2018,fgo迦勒底男性精选2018推荐召唤开启 fgo4月20日维护公告_游侠手游...
  14. 重装战姬电脑版模拟器怎么玩
  15. 浏览器不能上网,QQ能登录 问题解决方法
  16. 基于三周加速度传感器的计步器设计
  17. JS clientX、offsetX、pageX、screenX
  18. python中pprint模块
  19. 【阅读笔记】技术前沿(视觉-语言预训练、能量模型)
  20. MindMapper 与MindManager之间的区别

热门文章

  1. Android O Doze模式的状态
  2. android8.1 添加 doze白名单
  3. 数人云DCOS:坚持Mesos+Docker,图谋10万主机集群与机器学习扩容
  4. yandex浏览器_在浏览器中制作蛇游戏:Yandex的实践
  5. 视觉心理学-如何排版
  6. 公主同盟自然流程攻略(GBA版)第2关 狼之口
  7. 2010最佳Android和iPhone/iPad游戏应用出炉
  8. java 微信接入 关注和取消关注
  9. 画好高中男生校服有哪些技巧?
  10. Java多线程 - 锁