RedisTemplate常用操作方法總結(jié)(set、hash、list、string等)
Redis常用的數(shù)據(jù)類型:
- String
- Hash
- List
- Set
- zSet
- Sorted set
String類型
保存和讀取String(最常用的)
System.out.println("緩存正在設(shè)置。。。。。。。。。"); redisTemplate.opsForValue().set("key1","value1"); redisTemplate.opsForValue().set("key2","value2"); redisTemplate.opsForValue().set("key3","value3"); redisTemplate.opsForValue().set("key4","value4"); System.out.println("緩存已經(jīng)設(shè)置完畢。。。。。。。"); String result1=redisTemplate.opsForValue().get("key1").toString(); String result2=redisTemplate.opsForValue().get("key2").toString(); String result3=redisTemplate.opsForValue().get("key3").toString(); System.out.println("緩存結(jié)果為:result:"+result1+" "+result2+" "+result3);
判斷是否有key所對(duì)應(yīng)的值,有則返回true,沒(méi)有則返回false
redisTemplate.hasKey(key)
有則取出key值所對(duì)應(yīng)的值
redisTemplate.opsForValue().get(key)
刪除單個(gè)key值
redisTemplate.delete(key)
批量刪除key
redisTemplate.delete(keys) //其中keys:Collection<K> keys
將當(dāng)前傳入的key值序列化為byte[]類型
redisTemplate.dump(key)
設(shè)置過(guò)期時(shí)間
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值,返回一個(gè)Set集合類型
public Set<String> getPatternKey(String pattern) { return redisTemplate.keys(pattern); }
修改redis中key的名稱
public void renameKey(String oldKey, String newKey) { redisTemplate.rename(oldKey, newKey); }
返回傳入key所存儲(chǔ)的值的類型
public DataType getKeyType(String key) { return redisTemplate.type(key); }
如果舊值存在時(shí),將舊值改為新值
public Boolean renameOldKeyIfAbsent(String oldKey, String newKey) { return redisTemplate.renameIfAbsent(oldKey, newKey); }
從redis中隨機(jī)取出一個(gè)key
redisTemplate.randomKey()
返回當(dāng)前key所對(duì)應(yīng)的剩余過(guò)期時(shí)間
public Long getExpire(String key) { return redisTemplate.getExpire(key); }
返回剩余過(guò)期時(shí)間并且指定時(shí)間單位
public Long getExpire(String key, TimeUnit unit) { return redisTemplate.getExpire(key, unit); }
將key持久化保存
public Boolean persistKey(String key) { return redisTemplate.persist(key); }
將當(dāng)前數(shù)據(jù)庫(kù)的key移動(dòng)到指定redis中數(shù)據(jù)庫(kù)當(dāng)中
public Boolean moveToDbIndex(String key, int dbIndex) { return redisTemplate.move(key, dbIndex); }
設(shè)置當(dāng)前的key以及value值
redisTemplate.opsForValue().set(key, value)
設(shè)置當(dāng)前的key以及value值并且設(shè)置過(guò)期時(shí)間
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設(shè)置為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); }
在原有的值基礎(chǔ)上新增字符串到末尾
redisTemplate.opsForValue().append(key, value)
以增量的方式將double值存儲(chǔ)在變量中
public Double incrByDouble(String key, double increment) { return redisTemplate.opsForValue().increment(key, increment); }
通過(guò)increment(K key, long delta)方法以增量方式存儲(chǔ)long值(正值則自增,負(fù)值則自減)
public Long incrBy(String key, long increment) { return redisTemplate.opsForValue().increment(key, increment); }
如果對(duì)應(yīng)的map集合名稱不存在,則添加否則不做修改
Map valueMap = new HashMap(); valueMap.put("valueMap1","map1"); valueMap.put("valueMap2","map2"); valueMap.put("valueMap3","map3"); redisTemplate.opsForValue().multiSetIfAbsent(valueMap);
設(shè)置map集合到redis
Map valueMap = new HashMap(); valueMap.put("valueMap1","map1"); valueMap.put("valueMap2","map2"); valueMap.put("valueMap3","map3"); redisTemplate.opsForValue().multiSet(valueMap);
獲取字符串的長(zhǎng)度
redisTemplate.opsForValue().size(key)
用 value 參數(shù)覆寫(xiě)給定 key 所儲(chǔ)存的字符串值,從偏移量 offset 開(kāi)始
redisTemplate.opsForValue().set(key, value, offset)
重新設(shè)置key對(duì)應(yīng)的值,如果存在返回false,否則返回true
redisTemplate.opsForValue().setIfAbsent(key, value)
將值 value 關(guān)聯(lián)到 key,并將 key 的過(guò)期時(shí)間設(shè)為 timeout
redisTemplate.opsForValue().set(key, value, timeout, unit)
將二進(jìn)制第offset位值變?yōu)関alue
redisTemplate.opsForValue().setBit(key, offset, value)
對(duì)key所儲(chǔ)存的字符串值,獲取指定偏移量上的位(bit)
redisTemplate.opsForValue().getBit(key, offset)
Hash類型
Redis hash 是一個(gè)string類型的field和value的映射表,hash特別適合用于存儲(chǔ)對(duì)象。 Redis 中每個(gè) hash 可以存儲(chǔ) 2^32 - 1 鍵值對(duì)(40多億)。
Hash結(jié)構(gòu),保存和讀取map:
示例代碼:
Map<String,String> map=new HashMap<String,String>(); map.put("key1","value1"); map.put("key2","value2"); map.put("key3","value3"); map.put("key4","value4"); map.put("key5","value5"); redisTemplate.opsForHash().putAll("map1",map); Map<String,String> resultMap= redisTemplate.opsForHash().entries("map1"); List<String>reslutMapList=redisTemplate.opsForHash().values("map1"); Set<String>resultMapSet=redisTemplate.opsForHash().keys("map1"); String value=(String)redisTemplate.opsForHash().get("map1","key1"); System.out.println("value:"+value); System.out.println("resultMapSet:"+resultMapSet); System.out.println("resultMap:"+resultMap); System.out.println("resulreslutMapListtMap:"+reslutMapList);
運(yùn)行結(jié)果為:
value:value1
resultMapSet:[key1, key2, key5, key3, key4]
resultMap:{key3=value3, key2=value2, key1=value1, key5=value5, key4=value4}
resulreslutMapListtMap:[value1, value2, value5, value3, value4]
獲取變量中的指定map鍵是否有值,如果存在該map鍵則獲取值,沒(méi)有則返回null。
redisTemplate.opsForHash().get(key, field)
獲取變量中的鍵值對(duì)
public Map<Object, Object> hGetAll(String key) { return redisTemplate.opsForHash().entries(key); }
新增hashMap值
redisTemplate.opsForHash().put(key, hashKey, value)
以map集合的形式添加鍵值對(duì)
public void hPutAll(String key, Map<String, String> maps) { redisTemplate.opsForHash().putAll(key, maps); }
僅當(dāng)hashKey不存在時(shí)才設(shè)置
public Boolean hashPutIfAbsent(String key, String hashKey, String value) { return redisTemplate.opsForHash().putIfAbsent(key, hashKey, value); }
刪除一個(gè)或者多個(gè)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中的指定字段的整數(shù)值加上增量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表中字段的數(shù)量
redisTemplate.opsForHash().size(key)
獲取hash表中存在的所有的值
public List<Object> hValues(String key) { return redisTemplate.opsForHash().values(key); }
匹配獲取鍵值對(duì),ScanOptions.NONE為獲取全部鍵對(duì)
public Cursor<Entry<Object, Object>> hashScan(String key, ScanOptions options) { return redisTemplate.opsForHash().scan(key, options); }
List類型
保存和讀取list
示例代碼:
List<String> list1=new ArrayList<String>(); list1.add("a1"); list1.add("a2"); list1.add("a3"); List<String> list2=new ArrayList<String>(); list2.add("b1"); list2.add("b2"); list2.add("b3"); redisTemplate.opsForList().leftPush("listkey1",list1); redisTemplate.opsForList().rightPush("listkey2",list2); List<String> resultList1=(List<String>)redisTemplate.opsForList().leftPop("listkey1"); List<String> resultList2=(List<String>)redisTemplate.opsForList().rightPop("listkey2"); System.out.println("resultList1:"+resultList1); System.out.println("resultList2:"+resultList2);
運(yùn)行結(jié)果:
resultList1:[a1, a2, a3]
resultList2:[b1, b2, b3]
這里需要解釋一下:不管是leftPush還是rightPush都可以用leftPop或者rightPoP任意一種獲取到其中的值,不過(guò)就是獲取的遍歷方向不一樣。有學(xué)過(guò)數(shù)據(jù)結(jié)構(gòu)的人都知道里面循環(huán)鏈表是可以前后遍歷的,就和這里的場(chǎng)景是一樣的。如果還有不懂的話可以去看看這部分的源代碼,其實(shí)就是遍歷方向不同,所以效率也不同。所以最好leftPush用leftPoP遍歷,rightPush用rightPoP遍歷
通過(guò)索引獲取列表中的元素
redisTemplate.opsForList().index(key, index)
獲取列表指定范圍內(nèi)的元素(start開(kāi)始位置, 0是開(kāi)始位置,end 結(jié)束位置, -1返回所有)
redisTemplate.opsForList().range(key, start, end)
存儲(chǔ)在list的頭部,即添加一個(gè)就把它放在最前面的索引處
redisTemplate.opsForList().leftPush(key, value)
把多個(gè)值存入List中(value可以是多個(gè)值,也可以是一個(gè)Collection value)
redisTemplate.opsForList().leftPushAll(key, value)
List存在的時(shí)候再加入
redisTemplate.opsForList().leftPushIfPresent(key, value)
如果pivot處值存在則在pivot前面添加
redisTemplate.opsForList().leftPush(key, pivot, value)
按照先進(jìn)先出的順序來(lái)添加(value可以是多個(gè)值,或者是Collection var2)
redisTemplate.opsForList().rightPush(key, value) redisTemplate.opsForList().rightPushAll(key, value)
在pivot元素的右邊添加值
redisTemplate.opsForList().rightPush(key, pivot, value)
設(shè)置指定索引處元素的值
redisTemplate.opsForList().set(key, index, value)
移除并獲取列表中第一個(gè)元素(如果列表沒(méi)有元素會(huì)阻塞列表直到等待超時(shí)或發(fā)現(xiàn)可彈出元素為止)
redisTemplate.opsForList().leftPop(key) redisTemplate.opsForList().leftPop(key, timeout, unit)
移除并獲取列表最后一個(gè)元素
redisTemplate.opsForList().rightPop(key) redisTemplate.opsForList().rightPop(key, timeout, unit)
從一個(gè)隊(duì)列的右邊彈出一個(gè)元素并將這個(gè)元素放入另一個(gè)指定隊(duì)列的最左邊
redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey) redisTemplate.opsForList().rightPopAndLeftPush(sourceKey, destinationKey, timeout, unit)
刪除集合中值等于value的元素(index=0, 刪除所有值等于value的元素; index>0, 從頭部開(kāi)始刪除第一個(gè)值等于value的元素; index<0, 從尾部開(kāi)始刪除第一個(gè)值等于value的元素)
redisTemplate.opsForList().remove(key, index, value)
將List列表進(jìn)行剪裁
redisTemplate.opsForList().trim(key, start, end)
獲取當(dāng)前key的List列表長(zhǎng)度
redisTemplate.opsForList().size(key)
Set類型
保存和讀取Set:
代碼示例:
SetOperations<String, String> set = redisTemplate.opsForSet(); set.add("set1","22"); set.add("set1","33"); set.add("set1","44"); Set<String> resultSet =redisTemplate.opsForSet().members("set1"); System.out.println("resultSet:"+resultSet);
運(yùn)行結(jié)果為:
resultSet:[[set3, set2, set1]] jedis
添加元素
redisTemplate.opsForSet().add(key, values)
移除元素(單個(gè)值、多個(gè)值)
redisTemplate.opsForSet().remove(key, values)
刪除并且返回一個(gè)隨機(jī)的元素
redisTemplate.opsForSet().pop(key)
獲取集合的大小
redisTemplate.opsForSet().size(key)
判斷集合是否包含value
redisTemplate.opsForSet().isMember(key, value)
獲取兩個(gè)集合的交集(key對(duì)應(yīng)的無(wú)序集合與otherKey對(duì)應(yīng)的無(wú)序集合求交集)
redisTemplate.opsForSet().intersect(key, otherKey)
獲取多個(gè)集合的交集(Collection var2)
redisTemplate.opsForSet().intersect(key, otherKeys)
key集合與otherKey集合的交集存儲(chǔ)到destKey集合中(其中otherKey可以為單個(gè)值或者集合)
redisTemplate.opsForSet().intersectAndStore(key, otherKey, destKey)
key集合與多個(gè)集合的交集存儲(chǔ)到destKey無(wú)序集合中
redisTemplate.opsForSet().intersectAndStore(key, otherKeys, destKey)
獲取兩個(gè)或者多個(gè)集合的并集(otherKeys可以為單個(gè)值或者是集合)
redisTemplate.opsForSet().union(key, otherKeys)
key集合與otherKey集合的并集存儲(chǔ)到destKey中(otherKeys可以為單個(gè)值或者是集合)
redisTemplate.opsForSet().unionAndStore(key, otherKey, destKey)
獲取兩個(gè)或者多個(gè)集合的差集(otherKeys可以為單個(gè)值或者是集合)
redisTemplate.opsForSet().difference(key, otherKeys)
差集存儲(chǔ)到destKey中(otherKeys可以為單個(gè)值或者集合)
redisTemplate.opsForSet().differenceAndStore(key, otherKey, destKey)
隨機(jī)獲取集合中的一個(gè)元素
redisTemplate.opsForSet().randomMember(key)
獲取集合中的所有元素
redisTemplate.opsForSet().members(key)
隨機(jī)獲取集合中count個(gè)元素
redisTemplate.opsForSet().randomMembers(key, count)
獲取多個(gè)key無(wú)序集合中的元素(去重),count表示個(gè)數(shù)
redisTemplate.opsForSet().distinctRandomMembers(key, count)
遍歷set類似于Interator(ScanOptions.NONE為顯示所有的)
redisTemplate.opsForSet().scan(key, options)
zSet類型
ZSetOperations提供了一系列方法對(duì)有序集合進(jìn)行操作 添加元素(有序集合是按照元素的score值由小到大進(jìn)行排列)
redisTemplate.opsForZSet().add(key, value, score)
刪除對(duì)應(yīng)的value,value可以為多個(gè)值
redisTemplate.opsForZSet().remove(key, values)
增加元素的score值,并返回增加后的值
redisTemplate.opsForZSet().incrementScore(key, value, delta)
返回元素在集合的排名,有序集合是按照元素的score值由小到大排列
redisTemplate.opsForZSet().rank(key, value)
返回元素在集合的排名,按元素的score值由大到小排列
redisTemplate.opsForZSet().reverseRank(key, value)
獲取集合中給定區(qū)間的元素(start 開(kāi)始位置,end 結(jié)束位置, -1查詢所有)
redisTemplate.opsForZSet().reverseRangeWithScores(key, start,end)
按照Score值查詢集合中的元素,結(jié)果從小到大排序
redisTemplate.opsForZSet().reverseRangeByScore(key, min, max) redisTemplate.opsForZSet().reverseRangeByScoreWithScores(key, min, max) //返回值為:Set<ZSetOperations.TypedTuple<V>>
從高到低的排序集中獲取分?jǐn)?shù)在最小和最大值之間的元素
redisTemplate.opsForZSet().reverseRangeByScore(key, min, max, start, end)
根據(jù)score值獲取集合元素?cái)?shù)量
redisTemplate.opsForZSet().count(key, min, max)
獲取集合的大小
redisTemplate.opsForZSet().size(key) redisTemplate.opsForZSet().zCard(key)
獲取集合中key、value元素對(duì)應(yīng)的score值
redisTemplate.opsForZSet().score(key, value)
移除指定索引位置處的成員
redisTemplate.opsForZSet().removeRange(key, start, end)
移除指定score范圍的集合成員
redisTemplate.opsForZSet().removeRangeByScore(key, min, max)
獲取key和otherKey的并集并存儲(chǔ)在destKey中(其中otherKeys可以為單個(gè)字符串或者字符串集合)
redisTemplate.opsForZSet().unionAndStore(key, otherKey, destKey)
獲取key和otherKey的交集并存儲(chǔ)在destKey中(其中otherKeys可以為單個(gè)字符串或者字符串集合)
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()); }
到此這篇關(guān)于RedisTemplate常用操作方法總結(jié)(set、hash、list、string等)的文章就介紹到這了,更多相關(guān)RedisTemplate常用操作內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用RedisAtomicInteger計(jì)數(shù)出現(xiàn)少計(jì)問(wèn)題及解決
這篇文章主要介紹了使用RedisAtomicInteger計(jì)數(shù)出現(xiàn)少計(jì)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11Redis 單機(jī)安裝和哨兵模式集群安裝的實(shí)現(xiàn)
本文主要介紹了Redis 單機(jī)安裝和哨兵模式集群安裝的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07Redis高級(jí)玩法之利用SortedSet實(shí)現(xiàn)多維度排序的方法
Redis的SortedSet是可以根據(jù)score進(jìn)行排序的,以手機(jī)應(yīng)用商店的熱門(mén)榜單排序?yàn)槔?,根?jù)下載量倒序排列。接下來(lái)通過(guò)本文給大家分享Redis高級(jí)玩法之利用SortedSet實(shí)現(xiàn)多維度排序的方法,一起看看吧2019-07-07Redis出現(xiàn)(error)NOAUTH?Authentication?required.報(bào)錯(cuò)的解決辦法(秒懂!)
這篇文章主要給大家介紹了關(guān)于Redis出現(xiàn)(error)NOAUTH?Authentication?required.報(bào)錯(cuò)的解決辦法,對(duì)于 這個(gè)錯(cuò)誤這通常是因?yàn)镽edis服務(wù)器需要密碼進(jìn)行身份驗(yàn)證,但客戶端沒(méi)有提供正確的身份驗(yàn)證信息導(dǎo)致的,需要的朋友可以參考下2024-03-03redis服務(wù)器允許遠(yuǎn)程主機(jī)訪問(wèn)的方法
今天小編就為大家分享一篇redis服務(wù)器允許遠(yuǎn)程主機(jī)訪問(wèn)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05Redis 8種基本數(shù)據(jù)類型及常用命令和數(shù)據(jù)類型的應(yīng)用場(chǎng)景小結(jié)
Redis是一種基于內(nèi)存操作的數(shù)據(jù)庫(kù),其中多虧于高效的數(shù)據(jù)結(jié)構(gòu),本文主要介紹了Redis 8種基本數(shù)據(jù)類型及常用命令和數(shù)據(jù)類型的應(yīng)用場(chǎng)景小結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下2024-03-03Redis集群增加節(jié)點(diǎn)與刪除節(jié)點(diǎn)的方法詳解
這篇文章主要給大家介紹了關(guān)于Redis集群增加節(jié)點(diǎn)與刪除節(jié)點(diǎn)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09Redis事務(wù)涉及的watch、multi等命令詳解
這篇文章主要介紹了Redis事務(wù)涉及的watch、multi等命令,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2018-10-10