您好,登錄后才能下訂單哦!
小編給大家分享一下spring使用RedisTemplate操作Redis數(shù)據(jù)庫的案例,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
Redis是一個非關(guān)系型數(shù)據(jù)庫,具有很高的存取性能,一般用作緩存數(shù)據(jù)庫,減少正常存儲數(shù)據(jù)庫的壓力。
Redis可以存儲鍵與5種不同數(shù)據(jù)結(jié)構(gòu)類型之間的映射,這5種數(shù)據(jù)結(jié)構(gòu)類型分別為String(字符串)、List(列表)、Set(集合)、Hash(散列)和 Zset(有序集合)。
下面來對這5種數(shù)據(jù)結(jié)構(gòu)類型作簡單的介紹:
Spring封裝了RedisTemplate對象來進(jìn)行對Redis的各種操作,它支持所有的Redis原生的api。RedisTemplate位于spring-data-redis包下。RedisTemplate提供了redis各種操作、異常處理及序列化,支持發(fā)布訂閱,并對spring 3.1 cache進(jìn)行了實現(xiàn)。RedisTemplate提供了redis各種操作、異常處理及序列化,支持發(fā)布訂閱,并對spring 3.1 cache進(jìn)行了實現(xiàn)。RedisTemplate提供了redis各種操作、異常處理及序列化,支持發(fā)布訂閱,并對spring 3.1 cache進(jìn)行了實現(xiàn)。RedisTemplate提供了redis各種操作、異常處理及序列化,支持發(fā)布訂閱,并對spring 3.1 cache進(jìn)行了實現(xiàn)。
注意 RedisTemplate是一個key和value都是泛型的模板類,一般情況下key為String類型,如:RedisTemplate<String,Object>。
此外,如果沒特殊情況,切勿定義成RedisTemplate<Object, Object>,否則根據(jù)里氏替換原則,使用的時候會造成類型錯誤 。
spring-data-redis針對jedis提供了如下功能:
1.連接池自動管理,提供了一個高度封裝的“RedisTemplate”類
2.針對jedis客戶端中大量api進(jìn)行了歸類封裝,將同一類型操作封裝為operation接口
ValueOperations:簡單K-V操作
SetOperations:set類型數(shù)據(jù)操作
ZSetOperations:zset類型數(shù)據(jù)操作
HashOperations:針對map類型的數(shù)據(jù)操作
ListOperations:針對list類型的數(shù)據(jù)操作
2.RedisTemplate中定義了對5種數(shù)據(jù)結(jié)構(gòu)操作
redisTemplate.opsForValue();//操作字符串 redisTemplate.opsForHash();//操作hash redisTemplate.opsForList();//操作list redisTemplate.opsForSet();//操作set redisTemplate.opsForZSet();//操作有序set
其實這里的ops相當(dāng)于options, 是RedisTemplate對各種不同的Redis數(shù)據(jù)類型進(jìn)行操作。其實還有另外的方法:
redistempalate.boundValueOps redistempalate.boundSetOps redistempalate.boundListOps redistempalate.boundHashOps redistempalate.boundZSetOps
opsForXXX和boundXXXOps的區(qū)別?
XXX為value的類型,前者獲取一個operator,但是沒有指定操作的對象(key),可以在一個連接(事務(wù))內(nèi)操作多個key以及對應(yīng)的value;后者獲取了一個指定操作對象(key)的operator,在一個連接(事務(wù))內(nèi)只能操作這個key對應(yīng)的value。
關(guān)于計數(shù)的API(increment)有一個bug,需要各位使用中注意,通過increment計數(shù)以后,通過get方式獲取計數(shù)值的時候可能會拋出EOF異常(和本地的jdk以及redis的編譯版本有關(guān)),可以考慮使用boundValueOps(key).get(0,-1)獲取計數(shù)值。
1.值類型操作:
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations="classpath:spring/applicationContext-redis.xml") public class TestValue { @Autowired private RedisTemplate redisTemplate; @Test public void setValue(){ //存值,針對值類型,ops相當(dāng)于options redisTemplate.boundValueOps("name").set("itcast"); } @Test public void getValue(){ String str = (String) redisTemplate.boundValueOps("name").get(); System.out.println(str); } @Test public void deleteValue(){ redisTemplate.delete("name"); } }
2.集合類型操作之Set類型,無序,即存取順序不一定相同
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations="classpath:spring/applicationContext-redis.xml") public class TestSet { @Autowired private RedisTemplate redisTemplate; /** * 存入值 */ @Test public void setValue(){ redisTemplate.boundSetOps("nameset").add("曹操"); redisTemplate.boundSetOps("nameset").add("劉備"); redisTemplate.boundSetOps("nameset").add("孫權(quán)"); } /** * 提取值 */ @Test public void getValue(){ Set members = redisTemplate.boundSetOps("nameset").members(); System.out.println(members); } /** * 刪除集合中的某一個值 */ @Test public void deleteValue(){ redisTemplate.boundSetOps("nameset").remove("孫權(quán)"); } /** * 刪除整個集合 */ @Test public void deleteAllValue(){ redisTemplate.delete("nameset"); } }
輸出結(jié)果:[孫權(quán), 劉備, 曹操],此外,set類型的元素也不可重復(fù)。當(dāng)set沒有值的時候,會返回一個[]
3.List類型操作
list類型分為兩種,一種是左壓棧,一種是右壓棧
右壓棧:
/** * 右壓棧:后添加的對象排在后邊,相當(dāng)于隊列,相當(dāng)于先進(jìn)先出 */ @Test public void testSetValue1(){ redisTemplate.boundListOps("namelist1").rightPush("劉備"); redisTemplate.boundListOps("namelist1").rightPush("關(guān)羽"); redisTemplate.boundListOps("namelist1").rightPush("張飛"); } /** * 顯示右壓棧集合,range 表示查詢的索引,從第幾個查到第幾個,如果想查詢所有的數(shù)的話只能將第二個數(shù)寫得大一點(diǎn)。 */ @Test public void testGetValue1(){ List list = redisTemplate.boundListOps("namelist1").range(0, 10); System.out.println(list); }
運(yùn)行結(jié)果:[劉備, 關(guān)羽, 張飛],元素可以重復(fù)
左壓棧:
/** * 左壓棧:后添加的對象排在前邊,相當(dāng)于棧,先進(jìn)后出 */ @Test public void testSetValue2(){ redisTemplate.boundListOps("namelist2").leftPush("劉備"); redisTemplate.boundListOps("namelist2").leftPush("關(guān)羽"); redisTemplate.boundListOps("namelist2").leftPush("張飛"); } /** * 顯示左壓棧集合 */ @Test public void testGetValue2(){ List list = redisTemplate.boundListOps("namelist2").range(0, 10); System.out.println(list); }
運(yùn)行結(jié)果:[張飛, 關(guān)羽, 劉備]
根據(jù)索引查詢元素
/** * 查詢集合某個元素 */ @Test public void testSearchByIndex(){ String s = (String) redisTemplate.boundListOps("namelist1").index(1); System.out.println(s); }
運(yùn)行結(jié)果:返回索引為1的元素移除某個元素的值
/** * 移除集合某個元素,其中remove中第一個參數(shù)是移除的個數(shù) */ @Test public void testRemoveByIndex(){ redisTemplate.boundListOps("namelist1").remove(1, "關(guān)羽"); }
這里表示移除一個“關(guān)羽”。
4.Hash類型操作
@RunWith(SpringJUnit4ClassRunner.class) @ContextConfiguration(locations = "classpath:spring/applicationContext-redis.xml") public class TestHash { @Autowired private RedisTemplate redisTemplate; // 存值 @Test public void testSetValue() { redisTemplate.boundHashOps("namehash").put("a", "唐僧"); redisTemplate.boundHashOps("namehash").put("b", "悟空"); redisTemplate.boundHashOps("namehash").put("c", "八戒"); redisTemplate.boundHashOps("namehash").put("d", "沙僧"); } //獲取所有的key @Test public void testGetKeys() { Set s = redisTemplate.boundHashOps("namehash").keys(); System.out.println(s); } // 獲取所有的value @Test public void testGetValues() { List values = redisTemplate.boundHashOps("namehash").values(); System.out.println(values); } // 根據(jù)key獲取值 @Test public void testGetValueByKey() { Object object = redisTemplate.boundHashOps("namehash").get("b"); System.out.println(object); } //根據(jù)key移除值 @Test public void testRemoveValueByKey() { redisTemplate.boundHashOps("namehash").delete("c"); } }
1. 兩者的關(guān)系是StringRedisTemplate繼承RedisTemplate。
2. 兩者的數(shù)據(jù)是不共通的;也就是說StringRedisTemplate只能管理StringRedisTemplate里面的數(shù)據(jù),RedisTemplate只能管理RedisTemplate中的數(shù)據(jù)。
3. SDR默認(rèn)采用的序列化策略有兩種,一種是String的序列化策略,一種是JDK的序列化策略。
StringRedisTemplate默認(rèn)采用的是String的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplate默認(rèn)采用的是JDK的序列化策略,保存的key和value都是采用此策略序列化保存的。
RedisTemplate使用的序列類在在操作數(shù)據(jù)的時候,比如說存入數(shù)據(jù)會將數(shù)據(jù)先序列化成字節(jié)數(shù)組然后在存入Redis數(shù)據(jù)庫,這個時候打開Redis查看的時候,你會看到你的數(shù)據(jù)不是以可讀的形式展現(xiàn)的,而是以字節(jié)數(shù)組顯示,類似下面
當(dāng)然從Redis獲取數(shù)據(jù)的時候也會默認(rèn)將數(shù)據(jù)當(dāng)做字節(jié)數(shù)組轉(zhuǎn)化,這樣就會導(dǎo)致一個問題,當(dāng)需要獲取的數(shù)據(jù)不是以字節(jié)數(shù)組存在redis當(dāng)中而是正常的可讀的字符串的時候,比如說下面這種形式的數(shù)據(jù)
看完了這篇文章,相信你對“spring使用RedisTemplate操作Redis數(shù)據(jù)庫的案例”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。