SpringBoot中Redis的set、map、list、value、实体类等基本操作介绍

springboot技术学习 https://www.itkc8.com

今天给大家介绍一下SpringBoot中Redis的set、map、list、value等基本操作的具体使用方法

上一节中给大家介绍了如何在SpringBoot中搭建Redis缓存数据库,这一节就针对于Redis的具体操作进行介绍。

关于Redis的历史,以及目前的普及程度大家应该都比我还清楚吧。作为key-value的nosql数据库,Redis的功能还是特别强大的。

下面就来介绍一下Redis中一些常用的操作:

1.存储set值的案例介绍:

 

[java] view plain copy

  1. Set<String>set1=new HashSet<String>();  
  2. set1.add("set1");  
  3. set1.add("set2");  
  4. set1.add("set3");  
  5. redisTemplate.opsForSet().add("set1",set1);  
  6. Set<String> resultSet =redisTemplate.opsForSet().members("set1");  
  7. System.out.println("resultSet:"+resultSet);  

运行结果为:

 

[html] view plain copy

  1. resultSet:[[set3, set2, set1]]  

2.存储map值的案例介绍:

 

[java] view plain copy

  1. Map<String,String> map=new HashMap<String,String>();  
  2.       map.put("key1","value1");  
  3.       map.put("key2","value2");  
  4.       map.put("key3","value3");  
  5.       map.put("key4","value4");  
  6.       map.put("key5","value5");  
  7.       redisTemplate.opsForHash().putAll("map1",map);  
  8.       Map<String,String> resultMap= redisTemplate.opsForHash().entries("map1");  
  9.       List<String>reslutMapList=redisTemplate.opsForHash().values("map1");  
  10.       Set<String>resultMapSet=redisTemplate.opsForHash().keys("map1");  
  11.       String value=(String)redisTemplate.opsForHash().get("map1","key1");  
  12.       System.out.println("value:"+value);  
  13.       System.out.println("resultMapSet:"+resultMapSet);  
  14.       System.out.println("resultMap:"+resultMap);  
  15.       System.out.println("resulreslutMapListtMap:"+reslutMapList);  

运行结果为:

 

[html] view plain copy

  1. value:value1  
  2. resultMapSet:[key1, key2, key5, key3, key4]  
  3. resultMap:{key3=value3key2=value2key1=value1key5=value5key4=value4}  
  4. resulreslutMapListtMap:[value1, value2, value5, value3, value4]  

3.存储list值的案例介绍:

 

[java] view plain copy

  1. List<String> list1=new ArrayList<String>();  
  2.        list1.add("a1");  
  3.        list1.add("a2");  
  4.        list1.add("a3");  
  5.   
  6.        List<String> list2=new ArrayList<String>();  
  7.        list2.add("b1");  
  8.        list2.add("b2");  
  9.        list2.add("b3");  
  10.        redisTemplate.opsForList().leftPush("listkey1",list1);  
  11.        redisTemplate.opsForList().rightPush("listkey2",list2);  
  12.        List<String> resultList1=(List<String>)redisTemplate.opsForList().leftPop("listkey1");  
  13.        List<String> resultList2=(List<String>)redisTemplate.opsForList().rightPop("listkey2");  
  14.        System.out.println("resultList1:"+resultList1);  
  15.        System.out.println("resultList2:"+resultList2);  

运行结果为:

 

[html] view plain copy

  1. resultList1:[a1, a2, a3]  
  2. resultList2:[b1, b2, b3]  

这里需要解释一下:不管是leftPush还是rightPush都可以用leftPop或者rightPoP任意一种获取到其中的值,不过就是获取的遍历方向不一样。有学过数据结构的人都知道里面循环链表是可以前后遍历的,就和这里的场景是一样的。如果还有不懂的话可以去看看这部分的源代码,其实就是遍历方向不同,所以效率也不同。所以最好leftPush用leftPoP遍历,rightPush用rightPoP遍历。

4.存储key-value值的案例介绍:

 

[java] view plain copy

  1. System.out.println("缓存正在设置。。。。。。。。。");  
  2. redisTemplate.opsForValue().set("key1","value1");  
  3. redisTemplate.opsForValue().set("key2","value2");  
  4. redisTemplate.opsForValue().set("key3","value3");  
  5. redisTemplate.opsForValue().set("key4","value4");  
  6. System.out.println("缓存已经设置完毕。。。。。。。");  
  7. String result1=redisTemplate.opsForValue().get("key1").toString();  
  8. String result2=redisTemplate.opsForValue().get("key2").toString();  
  9. String result3=redisTemplate.opsForValue().get("key3").toString();  
  10. System.out.println("缓存结果为:result:"+result1+"  "+result2+"   "+result3);  

运行结果为:

 

[html] view plain copy

  1. 缓存正在设置。。。。。。。。。  
  2. 缓存已经设置完毕。。。。。。。  
  3. 缓存结果为:result:value1  value2   value3  

4.存储实体类的案例介绍:

 

[java] view plain copy

  1. List<Blacklist> blackList=blacklistDao.findAll();  
  2. redisTemplate.opsForValue().set("blacklist",blackList);  
  3. List<Blacklist> resultBlackList= redisTemplate.opsForValue().get("blacklist");  
  4. for(Blacklist blacklist:resultBlackList){  
  5.     System.out.println("ip:"+blacklist.getIp());  
  6. }  

实体类:

 

[java] view plain copy

  1. package example.entity;  
  2. import javax.persistence.*;  
  3. import java.io.Serializable;  
  4. import java.util.Date;  
  5. @Entity  
  6. @Table(name = "blacklist")  
  7. public class Blacklist implements Serializable  
  8. {  
  9.     private static final long serialVersionUID = -1L;  
  10.     @Id  
  11.     @GeneratedValue(strategy = GenerationType.AUTO)  
  12.     private int id;  
  13.   
  14.     @Column(name = "ip", nullable = true, length = 30)  
  15.     private String ip;  
  16.   
  17.     @Temporal(TemporalType.TIMESTAMP)  
  18.     private Date iptime; // 日期类型,格式:yyyy-MM-dd HH:mm:ss  
  19.   
  20.     public Blacklist() {  
  21.     }  
  22.   
  23.     public Blacklist(String ip, Date iptime) {  
  24.         this.ip = ip;  
  25.         this.iptime = iptime;  
  26.     }  
  27.   
  28.     public static long getSerialVersionUID() {  
  29.         return serialVersionUID;  
  30.     }  
  31.   
  32.     public int getId() {  
  33.         return id;  
  34.     }  
  35.   
  36.     public void setId(int id) {  
  37.         this.id = id;  
  38.     }  
  39.   
  40.     public String getIp() {  
  41.         return ip;  
  42.     }  
  43.   
  44.     public void setIp(String ip) {  
  45.         this.ip = ip;  
  46.     }  
  47.   
  48.     public Date getIptime() {  
  49.         return iptime;  
  50.     }  
  51.   
  52.     public void setIptime(Date iptime) {  
  53.         this.iptime = iptime;  
  54.     }  
  55. }  

运行结果为:

 

[html] view plain copy

  1. ip:127.0.0.2  
  2. ip:127.0.0.3  
  3. ip:127.0.0.4  
  4. ip:127.0.0.5  
  5. ip:127.0.0.10  
  6. ip:127.0.0.1  


这里需要注意的是:实体类一定要实现序列话,否者不管set的值为多少,最后存储的结果都是null的。

这样关于Redis一些常用的存储方法就介绍完了,下一节将会给大家介绍一下Redis如何实现数据库的同步。

其实也就是实现查询和更新分离,查询的时查询Redis缓存中的数据,更新操作的时候执行数据库操作,然后同步更新Redis中的相关键值。

springboot技术学习 https://www.itkc8.com

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值