zoukankan      html  css  js  c++  java
  • Redis缓存数据库常见操作

    Jedis的最为常见的操作。主要包括常用的列表(list)、集合(set)、有序集合(sorted set)、哈希表(hash)等数据结构,以及其他特性支持。

    参考资料:http://hello-nick-xu.iteye.com/blog/search?query=Jedis

    <一>. 使用list:
     可以使用列表模拟队列(queue)、堆栈(stack),并且支持双向的操作(L或者R)。
     1. 右边入队:

    Java代码  收藏代码
    1. jedis.rpush("userList""James");  

      2. 左边出队:右边出栈(rpop),即为对堆栈的操作。

    Java代码  收藏代码
    1. jedis.lpop("userList");  

      3. 返回列表范围:从0开始,到最后一个(-1) [包含] 

    Java代码  收藏代码
    1. List<String> userList = jedis.lrange("userList"0, -1);  

       Redis的TopN操作,即使用list完成:lrange
     4. 删除:使用key

    Java代码  收藏代码
    1. jedis.del("userList");  

      5. 设置:位置1处为新值

    Java代码  收藏代码
    1. jedis.lset("userList"1"Nick Xu");  

      6. 返回长度:

    Java代码  收藏代码
    1. Long size = jedis.llen("userList");  

      7. 进行裁剪:包含

    Java代码  收藏代码
    1. jedis.ltrim("userList"12);  

     
     <二>. 使用set:和列表不同,集合中的元素是无序的,因此元素也不能重复。
     1. 添加到set:可一次添加多个

    Java代码  收藏代码
    1. jedis.sadd("fruit""apple");  
    2. jedis.sadd("fruit""pear""watermelon");  
    3. jedis.sadd("fruit""apple");  

     2. 遍历集合:

    Java代码  收藏代码
    1. Set<String> fruit = jedis.smembers("fruit");  

      3. 移除元素:remove

    Java代码  收藏代码
    1. jedis.srem("fruit""pear");  

      4. 返回长度:

    Java代码  收藏代码
    1. Long size = jedis.scard("fruit");  

      5. 是否包含:

    Java代码  收藏代码
    1. Boolean isMember = jedis.sismember("fruit""pear");  

      6. 集合的操作:包括集合的交运算(sinter)、差集(sdiff)、并集(sunion)

    Java代码  收藏代码
    1. jedis.sadd("food""bread""milk");   
    2. Set<String> fruitFood = jedis.sunion("fruit""food");  

       
    <三>. 使用sorted set:有序集合在集合的基础上,增加了一个用于排序的参数。
     1. 有序集合:根据“第二个参数”进行排序。

    Java代码  收藏代码
    1. jedis.zadd("user"22"James");  

     2. 再次添加:元素相同时,更新为当前的权重。

    Java代码  收藏代码
    1. jedis.zadd("user"24"James");  

      3. zset的范围:找到从0到-1的所有元素。

    Java代码  收藏代码
    1. Set<String> user = jedis.zrange("user"0, -1);  

      4. 说明:我们可能还有一个疑虑,集合是怎么做到有序的呢?
       实际上,上述user的数据类型为java.util.LinkedHashSet
       
    <四>. 使用hash:
     1. 存放数据:使用HashMap

    Java代码  收藏代码
    1. Map<String, String>  capital = new HashMap<String, String>();  
    2. capital.put("shannxi""xi'an");  
    3. ...  
    4. jedis.hmset("capital", capital);  

       2. 获取数据:

    Java代码  收藏代码
    1. List<String> cities = jedis.hmget("capital""shannxi""shanghai");  

       
    <五>. 其他操作:
     1. 对key的操作:
      @ 对key的模糊查询:

    Java代码  收藏代码
    1. Set<String> keys = jedis.keys("*");  
    2. Set<String> keys = jedis.keys("user.userid.*");  

      @ 删除key:

    Java代码  收藏代码
    1. jedis.del("city");  

        @ 是否存在:

    Java代码  收藏代码
    1. Boolean isExists = jedis.exists("user.userid.14101");  

      2. 失效时间:
      @ expire:时间为5s

    Java代码  收藏代码
    1. jedis.setex("user.userid.14101"5"James");  

      @ 存活时间(ttl):time to live

    Java代码  收藏代码
    1. Long seconds = jedis.ttl("user.userid.14101");  

      @ 去掉key的expire设置:不再有失效时间

    Java代码  收藏代码
    1. jedis.persist("user.userid.14101");  

     3. 自增的整型:
      @ int类型采用string类型的方式存储:

    Java代码  收藏代码
    1. jedis.set("amount"100 + "");  

      @ 递增或递减:incr()/decr()

    Java代码  收藏代码
    1. jedis.incr("amount");  

      @ 增加或减少:incrBy()/decrBy()

    Java代码  收藏代码
    1. jedis.incrBy("amount"20);  

     4. 数据清空:
      @ 清空当前db:

    Java代码  收藏代码
    1. jedis.flushDB();  

        @ 清空所有db:

    Java代码  收藏代码
    1. jedis.flushAll();  

      5. 事务支持:
      @ 获取事务:

    Java代码  收藏代码
    1. Transaction tx = jedis.multi();  

        @ 批量操作:tx采用和jedis一致的API接口

    Java代码  收藏代码
    1. for(int i = 0;i < 10;i ++) {  
    2.      tx.set("key" + i, "value" + i);   
    3.      System.out.println("--------key" + i);  
    4.      Thread.sleep(1000);    
    5. }  

      @ 执行事务:针对每一个操作,返回其执行的结果,成功即为Ok

    Java代码  收藏代码
    1. List<Object> results = tx.exec();  
  • 相关阅读:
    排序算法(I)冒泡排序
    C#常用类string
    HashMap----工作原理
    Java计算字符串中字母出现的次数
    数据库优化
    线程和进程的区别(详细)
    SpringMVC工作原理
    jsp运行原理及运行过程
    一个公告
    SR
  • 原文地址:https://www.cnblogs.com/zhaojinhui/p/5144666.html
Copyright © 2011-2022 走看看