javascript
Spring中使用RedisTemplate操作Redis(spring-data-redis)
Redis 數(shù)據(jù)結(jié)構(gòu)簡(jiǎn)介
Redis可以存儲(chǔ)鍵與5種不同數(shù)據(jù)結(jié)構(gòu)類型之間的映射,這5種數(shù)據(jù)結(jié)構(gòu)類型分別為String(字符串)、List(列表)、Set(集合)、Hash(散列)和 Zset(有序集合)。
下面來(lái)對(duì)這5種數(shù)據(jù)結(jié)構(gòu)類型作簡(jiǎn)單的介紹:
| String | 可以是字符串、整數(shù)或者浮點(diǎn)數(shù) | 對(duì)整個(gè)字符串或者字符串的其中一部分執(zhí)行操作;對(duì)象和浮點(diǎn)數(shù)執(zhí)行自增(increment)或者自減(decrement) |
| List | 一個(gè)鏈表,鏈表上的每個(gè)節(jié)點(diǎn)都包含了一個(gè)字符串 | 從鏈表的兩端推入或者彈出元素;根據(jù)偏移量對(duì)鏈表進(jìn)行修剪(trim);讀取單個(gè)或者多個(gè)元素;根據(jù)值來(lái)查找或者移除元素 |
| Set | 包含字符串的無(wú)序收集器(unorderedcollection),并且被包含的每個(gè)字符串都是獨(dú)一無(wú)二的、各不相同 | 添加、獲取、移除單個(gè)元素;檢查一個(gè)元素是否存在于某個(gè)集合中;計(jì)算交集、并集、差集;從集合里賣弄隨機(jī)獲取元素 |
| Hash | 包含鍵值對(duì)的無(wú)序散列表 | 添加、獲取、移除單個(gè)鍵值對(duì);獲取所有鍵值對(duì) |
| Zset | 字符串成員(member)與浮點(diǎn)數(shù)分值(score)之間的有序映射,元素的排列順序由分值的大小決定 | 添加、獲取、刪除單個(gè)元素;根據(jù)分值范圍(range)或者成員來(lái)獲取元素 |
Redis 5種數(shù)據(jù)結(jié)構(gòu)的概念大致介紹到這邊,下面將結(jié)合Spring封裝的RedisTemplate來(lái)對(duì)這5種數(shù)據(jù)結(jié)構(gòu)的運(yùn)用進(jìn)行演示
RedisTemplate介紹
Spring封裝了RedisTemplate對(duì)象來(lái)進(jìn)行對(duì)Redis的各種操作,它支持所有的Redis原生的api。RedisTemplate位于spring-data-redis包下。
RedisTemplate在Spring代碼中的結(jié)構(gòu)如下:
org.springframework.data.redis.core Class RedisTemplate<K,V> java.lang.Objectorg.springframework.data.redis.core.RedisAccessororg.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>,否則根據(jù)里氏替換原則,使用的時(shí)候會(huì)造成類型錯(cuò)誤 。
V
- the Redis value type against which the template works
模板中的Redis value的類型
RedisTemplate中定義了對(duì)5種數(shù)據(jù)結(jié)構(gòu)操作
redisTemplate.opsForValue();//操作字符串 redisTemplate.opsForHash();//操作hash redisTemplate.opsForList();//操作list redisTemplate.opsForSet();//操作set redisTemplate.opsForZSet();//操作有序setStringRedisTemplate與RedisTemplate
-
兩者的關(guān)系是StringRedisTemplate繼承RedisTemplate。
-
兩者的數(shù)據(jù)是不共通的;也就是說(shuō)StringRedisTemplate只能管理StringRedisTemplate里面的數(shù)據(jù),RedisTemplate只能管理RedisTemplate中的數(shù)據(jù)。
-
SDR默認(rèn)采用的序列化策略有兩種,一種是String的序列化策略,一種是JDK的序列化策略。
StringRedisTemplate默認(rèn)采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplate默認(rèn)采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplate配置如下:
@Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);ObjectMapper om = new ObjectMapper();om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om);RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();template.setConnectionFactory(redisConnectionFactory);template.setKeySerializer(jackson2JsonRedisSerializer);template.setValueSerializer(jackson2JsonRedisSerializer);template.setHashKeySerializer(jackson2JsonRedisSerializer);template.setHashValueSerializer(jackson2JsonRedisSerializer);template.afterPropertiesSet();return template; }Redis的String數(shù)據(jù)結(jié)構(gòu) (推薦使用StringRedisTemplate)
注意:如果使用RedisTemplate需要更改序列化方式
RedisSerializer<String> stringSerializer = new StringRedisSerializer();template.setKeySerializer(stringSerializer );template.setValueSerializer(stringSerializer );template.setHashKeySerializer(stringSerializer );template.setHashValueSerializer(stringSerializer );public interface ValueOperations<K,V>
Redis operations for simple (or in Redis terminology 'string') values.
ValueOperations可以對(duì)String數(shù)據(jù)結(jié)構(gòu)進(jìn)行操作:
-
set void set(K key, V value);
使用:redisTemplate.opsForValue().set("name","tom"); 結(jié)果:redisTemplate.opsForValue().get("name") 輸出結(jié)果為tom -
set void set(K key, V value, long timeout, TimeUnit unit);
使用:redisTemplate.opsForValue().set("name","tom",10, TimeUnit.SECONDS); 結(jié)果:redisTemplate.opsForValue().get("name")由于設(shè)置的是10秒失效,十秒之內(nèi)查詢有結(jié)果,十秒之后返回為null -
set void set(K key, V value, long offset);
使用:template.opsForValue().set("key","hello world");template.opsForValue().set("key","redis", 6);System.out.println("***************"+template.opsForValue().get("key")); 結(jié)果:***************hello redis
該方法是用 value 參數(shù)覆寫(overwrite)給定 key 所儲(chǔ)存的字符串值,從偏移量 offset 開始 -
setIfAbsent Boolean setIfAbsent(K key, V value);
使用:System.out.println(template.opsForValue().setIfAbsent("multi1","multi1"));//false multi1之前已經(jīng)存在System.out.println(template.opsForValue().setIfAbsent("multi111","multi111"));//true multi111之前不存在 結(jié)果:false true
-
multiSet void multiSet(Map<? extends K, ? extends V> m);
使用:Map<String,String> maps = new HashMap<String, String>();maps.put("multi1","multi1");maps.put("multi2","multi2");maps.put("multi3","multi3");template.opsForValue().multiSet(maps);List<String> keys = new ArrayList<String>();keys.add("multi1");keys.add("multi2");keys.add("multi3");System.out.println(template.opsForValue().multiGet(keys)); 結(jié)果:[multi1, multi2, multi3]
為多個(gè)鍵分別設(shè)置它們的值 -
multiSetIfAbsent Boolean multiSetIfAbsent(Map<? extends K, ? extends V> m);
使用:Map<String,String> maps = new HashMap<String, String>();maps.put("multi11","multi11");maps.put("multi22","multi22");maps.put("multi33","multi33");Map<String,String> maps2 = new HashMap<String, String>();maps2.put("multi1","multi1");maps2.put("multi2","multi2");maps2.put("multi3","multi3");System.out.println(template.opsForValue().multiSetIfAbsent(maps));System.out.println(template.opsForValue().multiSetIfAbsent(maps2)); 結(jié)果:true false
為多個(gè)鍵分別設(shè)置它們的值,如果存在則返回false,不存在返回true -
get V get(Object key);
使用:template.opsForValue().set("key","hello world");System.out.println("***************"+template.opsForValue().get("key")); 結(jié)果:***************hello world -
getAndSet V getAndSet(K key, V value);
使用:template.opsForValue().set("getSetTest","test");System.out.println(template.opsForValue().getAndSet("getSetTest","test2")); 結(jié)果:test
設(shè)置鍵的字符串值并返回其舊值 -
multiGet List<V> multiGet(Collection<K> keys);
使用:Map<String,String> maps = new HashMap<String, String>();maps.put("multi1","multi1");maps.put("multi2","multi2");maps.put("multi3","multi3");template.opsForValue().multiSet(maps);List<String> keys = new ArrayList<String>();keys.add("multi1");keys.add("multi2");keys.add("multi3");System.out.println(template.opsForValue().multiGet(keys)); 結(jié)果:[multi1, multi2, multi3]
為多個(gè)鍵分別取出它們的值 -
increment Long increment(K key, long delta);
使用:template.opsForValue().increment("increlong",1);System.out.println("***************"+template.opsForValue().get("increlong")); 結(jié)果:***************1
支持整數(shù) -
increment Double increment(K key, double delta);
使用:template.opsForValue().increment("increlong",1.2);System.out.println("***************"+template.opsForValue().get("increlong")); 結(jié)果:***************2.2
也支持浮點(diǎn)數(shù) -
append Integer append(K key, String value);
使用:template.opsForValue().append("appendTest","Hello");System.out.println(template.opsForValue().get("appendTest"));template.opsForValue().append("appendTest","world");System.out.println(template.opsForValue().get("appendTest")); 結(jié)果:HelloHelloworld
如果key已經(jīng)存在并且是一個(gè)字符串,則該命令將該值追加到字符串的末尾。如果鍵不存在,則它被創(chuàng)建并設(shè)置為空字符串,因此APPEND在這種特殊情況下將類似于SET。 -
get String get(K key, long start, long end);
使用:appendTest對(duì)應(yīng)的value為Helloworld System.out.println("*********"+template.opsForValue().get("appendTest",0,5)); 結(jié)果:*********Hellow 使用:System.out.println("*********"+template.opsForValue().get("appendTest",0,-1)); 結(jié)果:*********Helloworld 使用:System.out.println("*********"+template.opsForValue().get("appendTest",-3,-1)); 結(jié)果:*********rld
截取key所對(duì)應(yīng)的value字符串 -
size Long size(K key);
使用:template.opsForValue().set("key","hello world");System.out.println("***************"+template.opsForValue().size("key")); 結(jié)果:***************11
返回key所對(duì)應(yīng)的value值得長(zhǎng)度 -
setBit Boolean setBit(K key, long offset, boolean value);
使用:template.opsForValue().set("bitTest","a");// 'a' 的ASCII碼是 97。轉(zhuǎn)換為二進(jìn)制是:01100001// 'b' 的ASCII碼是 98 轉(zhuǎn)換為二進(jìn)制是:01100010// 'c' 的ASCII碼是 99 轉(zhuǎn)換為二進(jìn)制是:01100011//因?yàn)槎M(jìn)制只有0和1,在setbit中true為1,false為0,因此我要變?yōu)?#39;b'的話第六位設(shè)置為1,第七位設(shè)置為0template.opsForValue().setBit("bitTest",6, true);template.opsForValue().setBit("bitTest",7, false);System.out.println(template.opsForValue().get("bitTest")); 結(jié)果:b
對(duì) key 所儲(chǔ)存的字符串值,設(shè)置或清除指定偏移量上的位(bit)
key鍵對(duì)應(yīng)的值value對(duì)應(yīng)的ascii碼,在offset的位置(從左向右數(shù))變?yōu)関alue -
getBit Boolean getBit(K key, long offset);
使用:System.out.println(template.opsForValue().getBit("bitTest",7)); 結(jié)果:false
獲取鍵對(duì)應(yīng)值的ascii碼的在offset處位值
Redis的List數(shù)據(jù)結(jié)構(gòu)
這邊我們把RedisTemplate序列化方式改回之前的
Jackson2JsonRedisSerializer<Object> jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>(Object.class);ObjectMapper om = new ObjectMapper();om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);jackson2JsonRedisSerializer.setObjectMapper(om); RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();template.setKeySerializer(jackson2JsonRedisSerializer);template.setValueSerializer(jackson2JsonRedisSerializer);template.setHashKeySerializer(jackson2JsonRedisSerializer);template.setHashValueSerializer(jackson2JsonRedisSerializer);public interface ListOperations<K,V>
Redis列表是簡(jiǎn)單的字符串列表,按照插入順序排序。你可以添加一個(gè)元素導(dǎo)列表的頭部(左邊)或者尾部(右邊)
ListOperations專門操作list列表:
-
List<V> range(K key, long start, long end);
使用:System.out.println(template.opsForList().range("list",0,-1)); 結(jié)果:[c#, c++, python, java, c#, c#]
返回存儲(chǔ)在鍵中的列表的指定元素。偏移開始和停止是基于零的索引,其中0是列表的第一個(gè)元素(列表的頭部),1是下一個(gè)元素 -
void trim(K key, long start, long end);
使用:System.out.println(template.opsForList().range("list",0,-1)); template.opsForList().trim("list",1,-1);//裁剪第一個(gè)元素 System.out.println(template.opsForList().range("list",0,-1)); 結(jié)果:[c#, c++, python, java, c#, c#] [c++, python, java, c#, c#]
修剪現(xiàn)有列表,使其只包含指定的指定范圍的元素,起始和停止都是基于0的索引 -
Long size(K key);
使用:System.out.println(template.opsForList().size("list")); 結(jié)果:6
返回存儲(chǔ)在鍵中的列表的長(zhǎng)度。如果鍵不存在,則將其解釋為空列表,并返回0。當(dāng)key存儲(chǔ)的值不是列表時(shí)返回錯(cuò)誤。 -
Long leftPush(K key, V value);
使用:template.opsForList().leftPush("list","java");template.opsForList().leftPush("list","python");template.opsForList().leftPush("list","c++"); 結(jié)果:返回的結(jié)果為推送操作后的列表的長(zhǎng)度 1 2 3
將所有指定的值插入存儲(chǔ)在鍵的列表的頭部。如果鍵不存在,則在執(zhí)行推送操作之前將其創(chuàng)建為空列表。(從左邊插入) -
Long leftPushAll(K key, V... values);
使用:String[] stringarrays = new String[]{"1","2","3"};template.opsForList().leftPushAll("listarray",stringarrays);System.out.println(template.opsForList().range("listarray",0,-1)); 結(jié)果:[3, 2, 1]
批量把一個(gè)數(shù)組插入到列表中 -
Long leftPushAll(K key, Collection<V> values);
使用:List<Object> strings = new ArrayList<Object>();strings.add("1");strings.add("2");strings.add("3");template.opsForList().leftPushAll("listcollection4", strings);System.out.println(template.opsForList().range("listcollection4",0,-1)); 結(jié)果:[3, 2, 1]
批量把一個(gè)集合插入到列表中 -
Long leftPushIfPresent(K key, V value);
使用:System.out.println(template.opsForList().leftPushIfPresent("leftPushIfPresent","aa"));System.out.println(template.opsForList().leftPushIfPresent("leftPushIfPresent","bb")); ==========分割線=========== System.out.println(template.opsForList().leftPush("leftPushIfPresent","aa"));System.out.println(template.opsForList().leftPushIfPresent("leftPushIfPresent","bb")); 結(jié)果: 0 0 ==========分割線=========== 1 2
只有存在key對(duì)應(yīng)的列表才能將這個(gè)value值插入到key所對(duì)應(yīng)的列表中 -
Long leftPush(K key, V pivot, V value);
使用:template.opsForList().leftPush("list","java","oc");System.out.print(template.opsForList().range("list",0,-1)); 結(jié)果:[c++, python, oc, java, c#, c#]
把value值放到key對(duì)應(yīng)列表中pivot值的左面,如果pivot值存在的話 -
Long rightPush(K key, V value);
使用:template.opsForList().rightPush("listRight","java");template.opsForList().rightPush("listRight","python");template.opsForList().rightPush("listRight","c++"); 結(jié)果: 1 2 3
將所有指定的值插入存儲(chǔ)在鍵的列表的頭部。如果鍵不存在,則在執(zhí)行推送操作之前將其創(chuàng)建為空列表。(從右邊插入) -
Long rightPushAll(K key, V... values);
使用:String[] stringarrays = new String[]{"1","2","3"};template.opsForList().rightPushAll("listarrayright",stringarrays);System.out.println(template.opsForList().range("listarrayright",0,-1)); 結(jié)果:[1, 2, 3] -
Long rightPushAll(K key, Collection<V> values);
使用:List<Object> strings = new ArrayList<Object>();strings.add("1");strings.add("2");strings.add("3");template.opsForList().rightPushAll("listcollectionright", strings);System.out.println(template.opsForList().range("listcollectionright",0,-1)); 結(jié)果:[1, 2, 3] -
Long rightPushIfPresent(K key, V value);
使用:System.out.println(template.opsForList().rightPushIfPresent("rightPushIfPresent","aa"));System.out.println(template.opsForList().rightPushIfPresent("rightPushIfPresent","bb"));System.out.println("==========分割線===========");System.out.println(template.opsForList().rightPush("rightPushIfPresent","aa"));System.out.println(template.opsForList().rightPushIfPresent("rightPushIfPresent","bb")); 結(jié)果:0 0 ==========分割線=========== 1 2
只有存在key對(duì)應(yīng)的列表才能將這個(gè)value值插入到key所對(duì)應(yīng)的列表中 -
Long rightPush(K key, V pivot, V value);
使用:System.out.println(template.opsForList().range("listRight",0,-1));template.opsForList().rightPush("listRight","python","oc");System.out.println(template.opsForList().range("listRight",0,-1)); 結(jié)果:[java, python, c++] [java, python, oc, c++]
把value值放到key對(duì)應(yīng)列表中pivot值的右面,如果pivot值存在的話 -
void set(K key, long index, V value);
使用:System.out.println(template.opsForList().range("listRight",0,-1));template.opsForList().set("listRight",1,"setValue");System.out.println(template.opsForList().range("listRight",0,-1)); 結(jié)果:[java, python, oc, c++] [java, setValue, oc, c++]
在列表中index的位置設(shè)置value值 -
Long remove(K key, long count, Object value);
使用:System.out.println(template.opsForList().range("listRight",0,-1));template.opsForList().remove("listRight",1,"setValue");//將刪除列表中存儲(chǔ)的列表中第一次次出現(xiàn)的“setValue”。System.out.println(template.opsForList().range("listRight",0,-1)); 結(jié)果:[java, setValue, oc, c++] [java, oc, c++]
從存儲(chǔ)在鍵中的列表中刪除等于值的元素的第一個(gè)計(jì)數(shù)事件。
計(jì)數(shù)參數(shù)以下列方式影響操作:
count> 0:刪除等于從頭到尾移動(dòng)的值的元素。
count <0:刪除等于從尾到頭移動(dòng)的值的元素。
count = 0:刪除等于value的所有元素。 -
V index(K key, long index);
使用:System.out.println(template.opsForList().range("listRight",0,-1)); System.out.println(template.opsForList().index("listRight",2)); 結(jié)果:[java, oc, c++] c++
根據(jù)下表獲取列表中的值,下標(biāo)是從0開始的 -
V leftPop(K key);
使用:System.out.println(template.opsForList().range("list",0,-1));System.out.println(template.opsForList().leftPop("list"));System.out.println(template.opsForList().range("list",0,-1)); 結(jié)果: [c++, python, oc, java, c#, c#] c++ [python, oc, java, c#, c#]
彈出最左邊的元素,彈出之后該值在列表中將不復(fù)存在 -
V leftPop(K key, long timeout, TimeUnit unit);
使用:用法與 leftPop(K key);一樣
移出并獲取列表的第一個(gè)元素, 如果列表沒有元素會(huì)阻塞列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止。 -
V rightPop(K key);
使用: System.out.println(template.opsForList().range("list",0,-1));System.out.println(template.opsForList().rightPop("list"));System.out.println(template.opsForList().range("list",0,-1)); 結(jié)果:[python, oc, java, c#, c#] c# [python, oc, java, c#]
彈出最右邊的元素,彈出之后該值在列表中將不復(fù)存在 -
V rightPop(K key, long timeout, TimeUnit unit);
使用:用法與 rightPop(K key);一樣
移出并獲取列表的最后一個(gè)元素, 如果列表沒有元素會(huì)阻塞列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止。 -
V rightPopAndLeftPush(K sourceKey, K destinationKey);
使用:System.out.println(template.opsForList().range("list",0,-1)); template.opsForList().rightPopAndLeftPush("list","rightPopAndLeftPush");System.out.println(template.opsForList().range("list",0,-1));System.out.println(template.opsForList().range("rightPopAndLeftPush",0,-1)); 結(jié)果:[oc, java,c#] [oc, java] [c#]
用于移除列表的最后一個(gè)元素,并將該元素添加到另一個(gè)列表并返回。 -
V rightPopAndLeftPush(K sourceKey, K destinationKey, long timeout, TimeUnit unit);
使用:用法與rightPopAndLeftPush(K sourceKey, K destinationKey)一樣
用于移除列表的最后一個(gè)元素,并將該元素添加到另一個(gè)列表并返回,如果列表沒有元素會(huì)阻塞列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止。
Redis的Hash數(shù)據(jù)機(jī)構(gòu)
Redis的散列可以讓用戶將多個(gè)鍵值對(duì)存儲(chǔ)到一個(gè)Redis鍵里面。
public interface HashOperations<H,HK,HV>
HashOperations提供一系列方法操作hash:
-
Long delete(H key, Object... hashKeys);
使用:System.out.println(template.opsForHash().delete("redisHash","name"));System.out.println(template.opsForHash().entries("redisHash")); 結(jié)果:1 {class=6, age=28.1}
刪除給定的哈希hashKeys -
Boolean hasKey(H key, Object hashKey);
使用:System.out.println(template.opsForHash().hasKey("redisHash","age"));System.out.println(template.opsForHash().hasKey("redisHash","ttt")); 結(jié)果:true false
確定哈希hashKey是否存在 -
HV get(H key, Object hashKey);
使用:System.out.println(template.opsForHash().get("redisHash","age")); 結(jié)果:26
從鍵中的哈希獲取給定hashKey的值 -
List<HV> multiGet(H key, Collection<HK> hashKeys);
使用:List<Object> kes = new ArrayList<Object>();kes.add("name");kes.add("age");System.out.println(template.opsForHash().multiGet("redisHash",kes)); 結(jié)果:[jack, 28.1]
從哈希中獲取給定hashKey的值 -
Long increment(H key, HK hashKey, long delta);
使用:System.out.println(template.opsForHash().get("redisHash","age"));System.out.println(template.opsForHash().increment("redisHash","age",1)); 結(jié)果:26 27
通過(guò)給定的delta增加散列hashKey的值(整型) -
Double increment(H key, HK hashKey, double delta);
使用:System.out.println(template.opsForHash().get("redisHash","age"));System.out.println(template.opsForHash().increment("redisHash","age",1.1)); 結(jié)果:27 28.1
通過(guò)給定的delta增加散列hashKey的值(浮點(diǎn)數(shù)) -
Set<HK> keys(H key);
使用:System.out.println(template.opsForHash().keys("redisHash1")); //redisHash1所對(duì)應(yīng)的散列表為{class=1, name=jack, age=27} 結(jié)果:[name, class, age]
獲取key所對(duì)應(yīng)的散列表的key -
Long size(H key);
使用:System.out.println(template.opsForHash().size("redisHash1")); //redisHash1所對(duì)應(yīng)的散列表為{class=1, name=jack, age=27} 結(jié)果:3
獲取key所對(duì)應(yīng)的散列表的大小個(gè)數(shù) -
void putAll(H key, Map<? extends HK, ? extends HV> m);
使用:Map<String,Object> testMap = new HashMap();testMap.put("name","jack");testMap.put("age",27);testMap.put("class","1");template.opsForHash().putAll("redisHash1",testMap);System.out.println(template.opsForHash().entries("redisHash1")); 結(jié)果:{class=1, name=jack, age=27}
使用m中提供的多個(gè)散列字段設(shè)置到key對(duì)應(yīng)的散列表中 -
void put(H key, HK hashKey, HV value);
使用:template.opsForHash().put("redisHash","name","tom");template.opsForHash().put("redisHash","age",26);template.opsForHash().put("redisHash","class","6"); System.out.println(template.opsForHash().entries("redisHash")); 結(jié)果:{age=26, class="6", name=tom}
設(shè)置散列hashKey的值 -
Boolean putIfAbsent(H key, HK hashKey, HV value);
使用:System.out.println(template.opsForHash().putIfAbsent("redisHash","age",30)); System.out.println(template.opsForHash().putIfAbsent("redisHash","kkk","kkk")); 結(jié)果:false true
僅當(dāng)hashKey不存在時(shí)才設(shè)置散列hashKey的值。 -
List<HV> values(H key);
使用:System.out.println(template.opsForHash().values("redisHash")); 結(jié)果:[tom, 26, 6]
獲取整個(gè)哈希存儲(chǔ)的值根據(jù)密鑰 -
Map<HK, HV> entries(H key);
使用:System.out.println(template.opsForHash().entries("redisHash")); 結(jié)果:{age=26, class="6", name=tom}
獲取整個(gè)哈希存儲(chǔ)根據(jù)密鑰 -
Cursor<Map.Entry<HK, HV>> scan(H key, ScanOptions options);
使用:Cursor<Map.Entry<Object, Object>> curosr = template.opsForHash().scan("redisHash", ScanOptions.ScanOptions.NONE);while(curosr.hasNext()){Map.Entry<Object, Object> entry = curosr.next();System.out.println(entry.getKey()+":"+entry.getValue());} 結(jié)果:age:28.1 class:6 kkk:kkk
使用Cursor在key的hash中迭代,相當(dāng)于迭代器。
Redis的Set數(shù)據(jù)結(jié)構(gòu)
Redis的Set是string類型的無(wú)序集合。集合成員是唯一的,這就意味著集合中不能出現(xiàn)重復(fù)的數(shù)據(jù)。
Redis 中 集合是通過(guò)哈希表實(shí)現(xiàn)的,所以添加,刪除,查找的復(fù)雜度都是O(1)。
public interface SetOperations<K,V>
SetOperations提供了對(duì)無(wú)序集合的一系列操作:
-
Long add(K key, V... values);
使用:String[] strarrays = new String[]{"strarr1","sgtarr2"};System.out.println(template.opsForSet().add("setTest", strarrays)); 結(jié)果:2
無(wú)序集合中添加元素,返回添加個(gè)數(shù)
也可以直接在add里面添加多個(gè)值 如:template.opsForSet().add("setTest","aaa","bbb") -
Long remove(K key, Object... values);
使用:String[] strarrays = new String[]{"strarr1","sgtarr2"}; System.out.println(template.opsForSet().remove("setTest",strarrays)); 結(jié)果:2
移除集合中一個(gè)或多個(gè)成員 -
V pop(K key);
使用:System.out.println(template.opsForSet().pop("setTest")); System.out.println(template.opsForSet().members("setTest")); 結(jié)果:bbb [aaa, ccc]
移除并返回集合中的一個(gè)隨機(jī)元素 -
Boolean move(K key, V value, K destKey);
使用:template.opsForSet().move("setTest","aaa","setTest2");System.out.println(template.opsForSet().members("setTest"));System.out.println(template.opsForSet().members("setTest2")); 結(jié)果:[ccc] [aaa]
將 member 元素從 source 集合移動(dòng)到 destination 集合 -
Long size(K key);
使用:System.out.println(template.opsForSet().size("setTest")); 結(jié)果:1
無(wú)序集合的大小長(zhǎng)度 -
Boolean isMember(K key, Object o);
使用:System.out.println(template.opsForSet().isMember("setTest","ccc"));System.out.println(template.opsForSet().isMember("setTest","asd")); 結(jié)果:true false
判斷 member 元素是否是集合 key 的成員 -
Set<V> intersect(K key, K otherKey);
使用:System.out.println(template.opsForSet().members("setTest"));System.out.println(template.opsForSet().members("setTest2"));System.out.println(template.opsForSet().intersect("setTest","setTest2")); 結(jié)果:[aaa, ccc] [aaa] [aaa]
key對(duì)應(yīng)的無(wú)序集合與otherKey對(duì)應(yīng)的無(wú)序集合求交集 -
Set<V> intersect(K key, Collection<K> otherKeys);
使用:System.out.println(template.opsForSet().members("setTest"));System.out.println(template.opsForSet().members("setTest2"));System.out.println(template.opsForSet().members("setTest3"));List<String> strlist = new ArrayList<String>();strlist.add("setTest2");strlist.add("setTest3");System.out.println(template.opsForSet().intersect("setTest",strlist)); 結(jié)果:[aaa, ccc] [aaa] [ccc, aaa] [aaa]
key對(duì)應(yīng)的無(wú)序集合與多個(gè)otherKey對(duì)應(yīng)的無(wú)序集合求交集
-
Long intersectAndStore(K key, K otherKey, K destKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest")); System.out.println("setTest2:" + template.opsForSet().members("setTest2")); System.out.println(template.opsForSet().intersectAndStore("setTest","setTest2","destKey1")); System.out.println(template.opsForSet().members("destKey1")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] 2 [aaa, ccc]
key無(wú)序集合與otherkey無(wú)序集合的交集存儲(chǔ)到destKey無(wú)序集合中 -
Long intersectAndStore(K key, Collection<K> otherKeys, K destKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println("setTest3:" + template.opsForSet().members("setTest3"));List<String> strlist = new ArrayList<String>();strlist.add("setTest2");strlist.add("setTest3");System.out.println(template.opsForSet().intersectAndStore("setTest",strlist,"destKey2"));System.out.println(template.opsForSet().members("destKey2")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] setTest3:[ccc, aaa] 2 [aaa, ccc]
key對(duì)應(yīng)的無(wú)序集合與多個(gè)otherKey對(duì)應(yīng)的無(wú)序集合求交集存儲(chǔ)到destKey無(wú)序集合中 -
Set<V> union(K key, K otherKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println(template.opsForSet().union("setTest","setTest2")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] [ccc, aaa, ddd, bbb]
key無(wú)序集合與otherKey無(wú)序集合的并集 -
Set<V> union(K key, Collection<K> otherKeys);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println("setTest3:" + template.opsForSet().members("setTest3"));List<String> strlist = new ArrayList<String>();strlist.add("setTest2");strlist.add("setTest3");System.out.println(template.opsForSet().union("setTest",strlist)); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] setTest3:[xxx, ccc, aaa] [ddd, xxx, bbb, aaa, ccc]
key無(wú)序集合與多個(gè)otherKey無(wú)序集合的并集 -
Long unionAndStore(K key, K otherKey, K destKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println(template.opsForSet().unionAndStore("setTest","setTest2","unionAndStoreTest1"));System.out.println("unionAndStoreTest1:" + template.opsForSet().members("unionAndStoreTest1")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] 4 unionAndStoreTest1:[ccc, aaa, ddd, bbb]
key無(wú)序集合與otherkey無(wú)序集合的并集存儲(chǔ)到destKey無(wú)序集合中 -
Long unionAndStore(K key, Collection<K> otherKeys, K destKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println("setTest3:" + template.opsForSet().members("setTest3"));List<String> strlist = new ArrayList<String>();strlist.add("setTest2");strlist.add("setTest3");System.out.println(template.opsForSet().unionAndStore("setTest",strlist,"unionAndStoreTest2"));System.out.println("unionAndStoreTest2:" + template.opsForSet().members("unionAndStoreTest2")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] setTest3:[xxx, ccc, aaa] 5 unionAndStoreTest2:[ddd, xxx, bbb, aaa, ccc]
key無(wú)序集合與多個(gè)otherkey無(wú)序集合的并集存儲(chǔ)到destKey無(wú)序集合中 -
Set<V> difference(K key, K otherKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println(template.opsForSet().difference("setTest","setTest2")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] [bbb, ddd]
key無(wú)序集合與otherKey無(wú)序集合的差集 -
Set<V> difference(K key, Collection<K> otherKeys);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println("setTest3:" + template.opsForSet().members("setTest3"));List<String> strlist = new ArrayList<String>();strlist.add("setTest2");strlist.add("setTest3");System.out.println(template.opsForSet().difference("setTest",strlist)); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] setTest3:[xxx, ccc, aaa] [bbb, ddd]
key無(wú)序集合與多個(gè)otherKey無(wú)序集合的差集 -
Long differenceAndStore(K key, K otherKey, K destKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println(template.opsForSet().differenceAndStore("setTest","setTest2","differenceAndStore1"));System.out.println("differenceAndStore1:" + template.opsForSet().members("differenceAndStore1")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] 2 differenceAndStore1:[bbb, ddd]
key無(wú)序集合與otherkey無(wú)序集合的差集存儲(chǔ)到destKey無(wú)序集合中 -
Long differenceAndStore(K key, Collection<K> otherKeys, K destKey);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTest2:" + template.opsForSet().members("setTest2"));System.out.println("setTest3:" + template.opsForSet().members("setTest3"));List<String> strlist = new ArrayList<String>();strlist.add("setTest2");strlist.add("setTest3");System.out.println(template.opsForSet().differenceAndStore("setTest",strlist,"differenceAndStore2"));System.out.println("differenceAndStore2:" + template.opsForSet().members("differenceAndStore2")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTest2:[ccc, aaa] setTest3:[xxx, ccc, aaa] 2 differenceAndStore2:[bbb, ddd]
key無(wú)序集合與多個(gè)otherkey無(wú)序集合的差集存儲(chǔ)到destKey無(wú)序集合中 -
Set<V> members(K key);
使用:System.out.println(template.opsForSet().members("setTest")); 結(jié)果:[ddd, bbb, aaa, ccc]
返回集合中的所有成員 -
V randomMember(K key);
使用:System.out.println("setTest:" + template.opsForSet().members("setTest"));System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest"));System.out.println("setTestrandomMember:" + template.opsForSet().randomMember("setTest")); 結(jié)果:setTest:[ddd, bbb, aaa, ccc] setTestrandomMember:aaa setTestrandomMember:bbb setTestrandomMember:aaa setTestrandomMember:ddd
隨機(jī)獲取key無(wú)序集合中的一個(gè)元素 -
Set<V> distinctRandomMembers(K key, long count);
使用:System.out.println("randomMembers:" + template.opsForSet().distinctRandomMembers("setTest",5)); 結(jié)果:randomMembers:[aaa, bbb, ddd, ccc]
獲取多個(gè)key無(wú)序集合中的元素(去重),count表示個(gè)數(shù) -
List<V> randomMembers(K key, long count);
使用:System.out.println("randomMembers:" + template.opsForSet().randomMembers("setTest",5)); 結(jié)果:randomMembers:[ccc, ddd, ddd, ddd, aaa]
獲取多個(gè)key無(wú)序集合中的元素,count表示個(gè)數(shù) -
Cursor<V> scan(K key, ScanOptions options);
使用: Cursor<Object> curosr = template.opsForSet().scan("setTest", ScanOptions.NONE);while(curosr.hasNext()){System.out.println(curosr.next());} 結(jié)果:ddd bbb aaa ccc
遍歷set
Redis的ZSet數(shù)據(jù)結(jié)構(gòu)
Redis有序集合和無(wú)序集合一樣也是string類型元素的集合,且不允許重復(fù)的成員。
不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)double類型的分?jǐn)?shù)。redis正是通過(guò)分?jǐn)?shù)來(lái)為集合中的成員進(jìn)行從小到大的排序。
有序集合的成員是唯一的,但分?jǐn)?shù)(score)卻可以重復(fù)。
public interface ZSetOperations<K,V>
ZSetOperations提供了一系列方法對(duì)有序集合進(jìn)行操作:
-
Boolean add(K key, V value, double score);
使用:System.out.println(template.opsForZSet().add("zset1","zset-1",1.0)); 結(jié)果:true
新增一個(gè)有序集合,存在的話為false,不存在的話為true -
Long add(K key, Set<TypedTuple<V>> tuples);
使用:ZSetOperations.TypedTuple<Object> objectTypedTuple1 = new DefaultTypedTuple<Object>("zset-5",9.6);ZSetOperations.TypedTuple<Object> objectTypedTuple2 = new DefaultTypedTuple<Object>("zset-6",9.9);Set<ZSetOperations.TypedTuple<Object>> tuples = new HashSet<ZSetOperations.TypedTuple<Object>>();tuples.add(objectTypedTuple1);tuples.add(objectTypedTuple2);System.out.println(template.opsForZSet().add("zset1",tuples));System.out.println(template.opsForZSet().range("zset1",0,-1)); 結(jié)果:[zset-1, zset-2, zset-3, zset-4, zset-5, zset-6]
新增一個(gè)有序集合 -
Long remove(K key, Object... values);
使用:System.out.println(template.opsForZSet().range("zset1",0,-1));System.out.println(template.opsForZSet().remove("zset1","zset-6"));System.out.println(template.opsForZSet().range("zset1",0,-1)); 結(jié)果:[zset-1, zset-2, zset-3, zset-4, zset-5, zset-6] 1 [zset-1, zset-2, zset-3, zset-4, zset-5]
從有序集合中移除一個(gè)或者多個(gè)元素 -
Double incrementScore(K key, V value, double delta);
使用:System.out.println(template.opsForZSet().incrementScore("zset1","zset-1",1.1)); //原為1.1 結(jié)果:2.2
增加元素的score值,并返回增加后的值 -
Long rank(K key, Object o);
使用:System.out.println(template.opsForZSet().range("zset1",0,-1));System.out.println(template.opsForZSet().rank("zset1","zset-2")); 結(jié)果:[zset-2, zset-1, zset-3, zset-4, zset-5] 0 //表明排名第一
返回有序集中指定成員的排名,其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Long reverseRank(K key, Object o);
使用:System.out.println(template.opsForZSet().range("zset1",0,-1));System.out.println(template.opsForZSet().reverseRank("zset1","zset-2")); 結(jié)果:[zset-2, zset-1, zset-3, zset-4, zset-5] 4 //遞減之后排到第五位去了
返回有序集中指定成員的排名,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Set<V> range(K key, long start, long end);
使用:System.out.println(template.opsForZSet().range("zset1",0,-1)); 結(jié)果:[zset-2, zset-1, zset-3, zset-4, zset-5]
通過(guò)索引區(qū)間返回有序集合成指定區(qū)間內(nèi)的成員,其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Set<TypedTuple<V>> rangeWithScores(K key, long start, long end);
使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("zset1",0,-1);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-2score:1.2 value:zset-1score:2.2 value:zset-3score:2.3 value:zset-4score:6.6 value:zset-5score:9.6
通過(guò)索引區(qū)間返回有序集合成指定區(qū)間內(nèi)的成員對(duì)象,其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Set<V> rangeByScore(K key, double min, double max);
使用:System.out.println(template.opsForZSet().rangeByScore("zset1",0,5)); 結(jié)果:[zset-2, zset-1, zset-3]
通過(guò)分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員,其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Set<TypedTuple<V>> rangeByScoreWithScores(K key, double min, double max);
使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeByScoreWithScores("zset1",0,5);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-2score:1.2 value:zset-1score:2.2 value:zset-3score:2.3
通過(guò)分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員對(duì)象,其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Set<V> rangeByScore(K key, double min, double max, long offset, long count);
使用: System.out.println(template.opsForZSet().rangeByScore("zset1",0,5));System.out.println(template.opsForZSet().rangeByScore("zset1",0,5,1,2)); 結(jié)果:[zset-2, zset-1, zset-3] [zset-1, zset-3]
通過(guò)分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員,并在索引范圍內(nèi),其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Set<TypedTuple<V>> rangeByScoreWithScores(K key, double min, double max, long offset, long count);
使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeByScoreWithScores("zset1",0,5,1,2);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-1score:2.2 value:zset-3score:2.3
通過(guò)分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員對(duì)象,并在索引范圍內(nèi),其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Set<V> reverseRange(K key, long start, long end);
使用:System.out.println(template.opsForZSet().reverseRange("zset1",0,-1)); 結(jié)果:[zset-5, zset-4, zset-3, zset-1, zset-2]
通過(guò)索引區(qū)間返回有序集合成指定區(qū)間內(nèi)的成員,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Set<TypedTuple<V>> reverseRangeWithScores(K key, long start, long end);
使用:Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().reverseRangeWithScores("zset1",0,-1);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-5score:9.6 value:zset-4score:6.6 value:zset-3score:2.3 value:zset-1score:2.2 value:zset-2score:1.2
通過(guò)索引區(qū)間返回有序集合成指定區(qū)間內(nèi)的成員對(duì)象,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Set<V> reverseRangeByScore(K key, double min, double max);
使用:與rangeByScore調(diào)用方法一樣,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Set<TypedTuple<V>> reverseRangeByScoreWithScores(K key, double min, double max);
使用:與rangeByScoreWithScores調(diào)用方法一樣,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Set<V> reverseRangeByScore(K key, double min, double max, long offset, long count);
使用:與rangeByScore調(diào)用方法一樣,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Set<TypedTuple<V>> reverseRangeByScoreWithScores(K key, double min, double max, long offset, long count);
使用:與rangeByScoreWithScores調(diào)用方法一樣,其中有序集成員按分?jǐn)?shù)值遞減(從大到小)順序排列 -
Long count(K key, double min, double max);
使用:System.out.println(template.opsForZSet().rangeByScore("zset1",0,5));System.out.println(template.opsForZSet().count("zset1",0,5)); 結(jié)果:[zset-2, zset-1, zset-3] 3
通過(guò)分?jǐn)?shù)返回有序集合指定區(qū)間內(nèi)的成員個(gè)數(shù) -
Long size(K key);
使用:System.out.println(template.opsForZSet().size("zset1")); 結(jié)果:6
獲取有序集合的成員數(shù),內(nèi)部調(diào)用的就是zCard方法 -
Long zCard(K key);
使用:System.out.println(template.opsForZSet().zCard("zset1")); 結(jié)果:6
獲取有序集合的成員數(shù) -
Double score(K key, Object o);
使用:System.out.println(template.opsForZSet().score("zset1","zset-1")); 結(jié)果:2.2
獲取指定成員的score值 -
Long removeRange(K key, long start, long end);
使用:System.out.println(template.opsForZSet().range("zset2",0,-1));System.out.println(template.opsForZSet().removeRange("zset2",1,2));System.out.println(template.opsForZSet().range("zset2",0,-1)); 結(jié)果:[zset-1, zset-2, zset-3, zset-4] 2 [zset-1, zset-4]
移除指定索引位置的成員,其中有序集成員按分?jǐn)?shù)值遞增(從小到大)順序排列 -
Long removeRangeByScore(K key, double min, double max);
使用://System.out.println(template.opsForZSet().add("zset2","zset-1",1.1));//System.out.println(template.opsForZSet().add("zset2","zset-2",1.2));//System.out.println(template.opsForZSet().add("zset2","zset-3",2.3));//System.out.println(template.opsForZSet().add("zset2","zset-4",6.6)); System.out.println(template.opsForZSet().range("zset2",0,-1)); System.out.println(template.opsForZSet().removeRangeByScore("zset2",2,3));System.out.println(template.opsForZSet().range("zset2",0,-1)); 結(jié)果:[zset-1, zset-2, zset-3,zset-4] 1 [zset-1, zset-2, zset-4]
根據(jù)指定的score值得范圍來(lái)移除成員 -
Long unionAndStore(K key, K otherKey, K destKey);
使用:System.out.println(template.opsForZSet().add("zzset1","zset-1",1.0));System.out.println(template.opsForZSet().add("zzset1","zset-2",2.0));System.out.println(template.opsForZSet().add("zzset1","zset-3",3.0));System.out.println(template.opsForZSet().add("zzset1","zset-4",6.0));System.out.println(template.opsForZSet().add("zzset2","zset-1",1.0));System.out.println(template.opsForZSet().add("zzset2","zset-2",2.0));System.out.println(template.opsForZSet().add("zzset2","zset-3",3.0));System.out.println(template.opsForZSet().add("zzset2","zset-4",6.0));System.out.println(template.opsForZSet().add("zzset2","zset-5",7.0));System.out.println(template.opsForZSet().unionAndStore("zzset1","zzset2","destZset11"));Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset11",0,-1);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-1score:2.0 value:zset-2score:4.0 value:zset-3score:6.0 value:zset-5score:7.0 value:zset-4score:12.0
計(jì)算給定的一個(gè)有序集的并集,并存儲(chǔ)在新的 destKey中,key相同的話會(huì)把score值相加 -
Long unionAndStore(K key, Collection<K> otherKeys, K destKey);
使用://System.out.println(template.opsForZSet().add("zzset1","zset-1",1.0));//System.out.println(template.opsForZSet().add("zzset1","zset-2",2.0));//System.out.println(template.opsForZSet().add("zzset1","zset-3",3.0));//System.out.println(template.opsForZSet().add("zzset1","zset-4",6.0));////System.out.println(template.opsForZSet().add("zzset2","zset-1",1.0));//System.out.println(template.opsForZSet().add("zzset2","zset-2",2.0));//System.out.println(template.opsForZSet().add("zzset2","zset-3",3.0));//System.out.println(template.opsForZSet().add("zzset2","zset-4",6.0));//System.out.println(template.opsForZSet().add("zzset2","zset-5",7.0));System.out.println(template.opsForZSet().add("zzset3","zset-1",1.0));System.out.println(template.opsForZSet().add("zzset3","zset-2",2.0));System.out.println(template.opsForZSet().add("zzset3","zset-3",3.0));System.out.println(template.opsForZSet().add("zzset3","zset-4",6.0));System.out.println(template.opsForZSet().add("zzset3","zset-5",7.0));List<String> stringList = new ArrayList<String>();stringList.add("zzset2");stringList.add("zzset3");System.out.println(template.opsForZSet().unionAndStore("zzset1",stringList,"destZset22"));Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset22",0,-1);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-1score:3.0 value:zset-2score:6.0 value:zset-3score:9.0 value:zset-5score:14.0 value:zset-4score:18.0
計(jì)算給定的多個(gè)有序集的并集,并存儲(chǔ)在新的 destKey中 -
Long intersectAndStore(K key, K otherKey, K destKey);
使用:System.out.println(template.opsForZSet().intersectAndStore("zzset1","zzset2","destZset33"));Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset33",0,-1);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-1score:2.0 value:zset-2score:4.0 value:zset-3score:6.0 value:zset-4score:12.0
計(jì)算給定的一個(gè)或多個(gè)有序集的交集并將結(jié)果集存儲(chǔ)在新的有序集合 key 中 -
Long intersectAndStore(K key, Collection<K> otherKeys, K destKey);
使用:List<String> stringList = new ArrayList<String>();stringList.add("zzset2");stringList.add("zzset3");System.out.println(template.opsForZSet().intersectAndStore("zzset1",stringList,"destZset44"));Set<ZSetOperations.TypedTuple<Object>> tuples = template.opsForZSet().rangeWithScores("destZset44",0,-1);Iterator<ZSetOperations.TypedTuple<Object>> iterator = tuples.iterator();while (iterator.hasNext()){ZSetOperations.TypedTuple<Object> typedTuple = iterator.next();System.out.println("value:" + typedTuple.getValue() + "score:" + typedTuple.getScore());} 結(jié)果:value:zset-1score:3.0 value:zset-2score:6.0 value:zset-3score:9.0 value:zset-4score:18.0
計(jì)算給定的一個(gè)或多個(gè)有序集的交集并將結(jié)果集存儲(chǔ)在新的有序集合 key 中 -
Cursor<TypedTuple<V>> scan(K key, ScanOptions options);
使用: Cursor<ZSetOperations.TypedTuple<Object>> cursor = template.opsForZSet().scan("zzset1", ScanOptions.NONE);while (cursor.hasNext()){ZSetOperations.TypedTuple<Object> item = cursor.next();System.out.println(item.getValue() + ":" + item.getScore());} 結(jié)果:zset-1:1.0 zset-2:2.0 zset-3:3.0 zset-4:6.0
遍歷zset
注:TimeUnit是java.util.concurrent包下面的一個(gè)類,表示給定單元粒度的時(shí)間段
常用的顆粒度
?
轉(zhuǎn)載于:https://www.cnblogs.com/alsf/p/9705018.html
總結(jié)
以上是生活随笔為你收集整理的Spring中使用RedisTemplate操作Redis(spring-data-redis)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: UI自动化之特殊处理三(日期控件\表格\
- 下一篇: P4048 [JSOI2010]冷冻波