SpringBoot中Redis的set、map、list、value、實體類等基本操作介紹

來源:互聯網
上載者:User
今天給大家介紹一下SpringBoot中Redis的set、map、list、value等基本操作的具體使用方法

上一節中給大家介紹了如何在SpringBoot中搭建Redis快取資料庫,這一節就針對於Redis的具體操作進行介紹。

關於Redis的曆史,以及目前的普及程度大家應該都比我還清楚吧。作為key-value的nosql資料庫,Redis的功能還是特彆強大的。

下面就來介紹一下Redis中一些常用的操作:

1.儲存set值的案例介紹:

        Set<String>set1=new HashSet<String>();        set1.add("set1");        set1.add("set2");        set1.add("set3");        redisTemplate.opsForSet().add("set1",set1);        Set<String> resultSet =redisTemplate.opsForSet().members("set1");        System.out.println("resultSet:"+resultSet);
運行結果為:

resultSet:[[set3, set2, set1]]
2.儲存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);
運行結果為:

value:value1resultMapSet:[key1, key2, key5, key3, key4]resultMap:{key3=value3, key2=value2, key1=value1, key5=value5, key4=value4}resulreslutMapListtMap:[value1, value2, value5, value3, value4]
3.儲存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);
運行結果為:

resultList1:[a1, a2, a3]resultList2:[b1, b2, b3]
這裡需要解釋一下:不管是leftPush還是rightPush都可以用leftPop或者rightPoP任意一種擷取到其中的值,不過就是擷取的遍曆方向不一樣。有學過資料結構的人都知道裡面迴圈鏈表是可以前後遍曆的,就和這裡的情境是一樣的。如果還有不懂的話可以去看看這部分的原始碼,其實就是遍曆方向不同,所以效率也不同。所以最好leftPush用leftPoP遍曆,rightPush用rightPoP遍曆。

4.儲存key-value值的案例介紹:

        System.out.println("緩衝正在設定。。。。。。。。。");        redisTemplate.opsForValue().set("key1","value1");        redisTemplate.opsForValue().set("key2","value2");        redisTemplate.opsForValue().set("key3","value3");        redisTemplate.opsForValue().set("key4","value4");        System.out.println("緩衝已經設定完畢。。。。。。。");        String result1=redisTemplate.opsForValue().get("key1").toString();        String result2=redisTemplate.opsForValue().get("key2").toString();        String result3=redisTemplate.opsForValue().get("key3").toString();        System.out.println("緩衝結果為:result:"+result1+"  "+result2+"   "+result3);
運行結果為:

緩衝正在設定。。。。。。。。。緩衝已經設定完畢。。。。。。。緩衝結果為:result:value1  value2   value3
4.儲存實體類的案例介紹:
        List<Blacklist> blackList=blacklistDao.findAll();        redisTemplate.opsForValue().set("blacklist",blackList);        List<Blacklist> resultBlackList= redisTemplate.opsForValue().get("blacklist");        for(Blacklist blacklist:resultBlackList){            System.out.println("ip:"+blacklist.getIp());        }

實體類:

package example.entity;import javax.persistence.*;import java.io.Serializable;import java.util.Date;@Entity@Table(name = "blacklist")public class Blacklist implements Serializable{    private static final long serialVersionUID = -1L;    @Id    @GeneratedValue(strategy = GenerationType.AUTO)    private int id;    @Column(name = "ip", nullable = true, length = 30)    private String ip;    @Temporal(TemporalType.TIMESTAMP)    private Date iptime; // 日期類型,格式:yyyy-MM-dd HH:mm:ss    public Blacklist() {    }    public Blacklist(String ip, Date iptime) {        this.ip = ip;        this.iptime = iptime;    }    public static long getSerialVersionUID() {        return serialVersionUID;    }    public int getId() {        return id;    }    public void setId(int id) {        this.id = id;    }    public String getIp() {        return ip;    }    public void setIp(String ip) {        this.ip = ip;    }    public Date getIptime() {        return iptime;    }    public void setIptime(Date iptime) {        this.iptime = iptime;    }}

運行結果為:

ip:127.0.0.2ip:127.0.0.3ip:127.0.0.4ip:127.0.0.5ip:127.0.0.10ip:127.0.0.1

這裡需要注意的是:實體類一定要實現序列話,否者不管set的值為多少,最後儲存的結果都是null的。

這樣關於Redis一些常用的儲存方法就介紹完了,下一節將會給大家介紹一下Redis如何?資料庫的同步。

其實也就是實現查詢和更新分離,查詢的時查詢Redis緩衝中的資料,更新操作的時候執行資料庫操作,然後同步更新Redis中的相關索引值。
明天就國慶了,我在這裡提前祝大家國慶快樂呀。我會在國慶後更新部落格內容,謝謝大家的觀看閱讀。

如果大家對文章有什麼問題或者疑意之類的,可以加我訂閱號在上面留言,訂閱號上面我會定期更新最新部落格。如果嫌麻煩可以直接加我wechat:lzqcode



相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.