zoukankan      html  css  js  c++  java
  • redis 系列11 列表对象

    一. 列表对象概述

      Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。在第9篇中讲到了列表对象的编码可以是ziplist或者linkedlist。ziplist编码的列表对象使用压缩列表作为底层实现,每个压缩列表节点(entry)保存了一个列表元素。例如使用rpush命令将创建一个列表对象作为numbers键的值。

        127.0.0.1:6379> rpush numbers 1 "three" 5
        (integer) 3
        127.0.0.1:6379> object encoding  numbers
        "quicklist"

      通过上面查看底层数据结构并不是ziplist,而是quicklist结构。 该结构是在redis 3.2版本中新加的数据结构,用在列表的底层实现,由ziplist组成的双向链表。链表中的每一个节点都以压缩列表ziplist的结构保存着数据,而ziplist有多个entry节点,保存着数据。相当与一个quicklist节点保存的是一片数据,而不再是一个数据。

      例如:一个quicklist结构有4个quicklistNode节点,每个节点都保存着1个ziplist结构,每个ziplist的大小不超过8kb,ziplist的entry节点中的value成员保存着数据。以后在深入了解quicklist数据结构。

    二. 列表对象命令

         -- rpush 命令可向list的右边(尾部)添加一个新元素,读出来就是(A,B,first)。
        127.0.0.1:6379> rpush mylist A
        (integer) 1
        127.0.0.1:6379> rpush mylist B
        (integer) 2
        127.0.0.1:6379> rpush mylist first
        (integer) 3
        
         -- lrange 命令获取列表指定范围内的元素,带有两个索引,一定范围的第一个和最后一个元素。-1表示最后一个元素,-2表示list中的倒数第二个元素,以此类推。下面是读出列表mylist。
        127.0.0.1:6379> lrange mylist 0 -1
        1) "A"
        2) "B"
        3) "first"
    
         -- lpush命令可向list的左边(头部)添加一个新元素,读出来就是(first,B,A)。
        127.0.0.1:6379> lpush mylist A
        (integer) 1
        127.0.0.1:6379> lpush mylist B
        (integer) 2
        127.0.0.1:6379> lpush mylist first
        (integer) 3
        127.0.0.1:6379> lrange mylist 0 -1
        1) "first"
        2) "B"
        3) "A"
    
         -- Blpop 命令移出第一个元素并返回列表的第一个元素. 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。下面是移除了每一个first元素。
        127.0.0.1:6379> blpop mylist 5
        1) "mylist"
        2) "first"
        127.0.0.1:6379> lrange mylist 0 -1
        1) "B"
        2) "A"
    
        --  Brpop 命令移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。下面二个元素,移除了最后一个。
        127.0.0.1:6379> lrange mylist 0 -1
        1) "B"
        2) "A"
        127.0.0.1:6379> brpop mylist 5
        1) "mylist"
        2) "A"
        127.0.0.1:6379> lrange mylist 0 -1
        1) "B"
    
        -- Brpoplpush 命令从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
    -- 下面mylist2列表获取了mylist列表的一个元素
    127.0.0.1:6379> brpoplpush mylist mylist2 5000 "B" --弹出一个值, 移到了mylist2中,设置超时时间 127.0.0.1:6379> lrange mylist 0 -1 (empty list or set) -- 空列表 127.0.0.1:6379> lrange mylist2 0 -1 1) "B" 2) "C" -- Lindex 命令用于通过索引获取列表中的元素。你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。下面获取mylist2的第一个元素。 127.0.0.1:6379> lrange mylist2 0 -1 1) "B" 2) "C" 127.0.0.1:6379> lindex mylist2 0 "B"
    -- Linsert 命令用于在列表的元素前或者后插入元素。格式: LINSERT key BEFORE|AFTER pivot value, 下面将A插入到已有C元素的前面。 127.0.0.1:6379> linsert mylist2 before "C" "A" (integer) 3 127.0.0.1:6379> lrange mylist2 0 -1 1) "B" 2) "A" 3) "C"
        --Llen 命令用于返回列表的长度。
        127.0.0.1:6379> llen mylist2
        (integer) 3
        --Lpop 命令用于移除并返回列表的第一个元素
        127.0.0.1:6379> lpop mylist2
        "B"
        127.0.0.1:6379> lrange mylist2 0 -1
        1) "A"
        2) "C"
    
       --Lpush 命令将一个或多个值插入到列表头部, 上面有单个元素添加,还可以是多个元素添加,这里不在演示。
      --Lpushx 将一个或多个值插入到已存在的列表头部。key的列表中必须要元素。
        127.0.0.1:6379> lpushx mylist "A"
        (integer) 0  --添加失败,因为mylist是空列表
        127.0.0.1:6379> lrange mylist 0 -1
        (empty list or set)
        127.0.0.1:6379> lpush mylist A B
        (integer) 2
        127.0.0.1:6379> lpushx mylist C
        (integer) 3 -- 添加成功。
        127.0.0.1:6379> lrange mylist 0 -1
        1) "C"
        2) "B"
        3) "A"
    
        --  Lrem 根据参数 COUNT 的值,移除列表中与参数 VALUE 相等的元素。 意思是列表中元素与value相等的,移除count个。
        127.0.0.1:6379> lpush my "one" "two" "three" "one"
        (integer) 4
        127.0.0.1:6379> lrange my 0 -1
        1) "one"
        2) "three"
        3) "two"
        4) "one"
        127.0.0.1:6379> lrem my 1 "one"  --移除1个one元素
        (integer) 1
        127.0.0.1:6379> lrange my 0 -1
        1) "three"
        2) "two"
        3) "one"
    
        -- Lset 通过索引来设置元素的值。
        127.0.0.1:6379> lrange my 0 -1
        1) "three"
        2) "two"
        3) "one"
        127.0.0.1:6379> lset my 2 "four" 
        OK  -- 第三个元素的值从onw 改为了four
        127.0.0.1:6379> lrange my 0 -1
        1) "three"
        2) "two"
        3) "four"
    
        --Ltrim 对一个列表只保留指定区间内的元素。不在指定区间之内的元素都将被删除。下标 0 表示列表的第一个元素,以 1 表示列表的第二个元素。 格式 LTRIM KEY_NAME START STOP
        127.0.0.1:6379> lrange my 0 -1
        1) "three"
        2) "two"
        3) "four"
        127.0.0.1:6379> ltrim my 1 -1
        OK  -- 第一个元素将被删除
        127.0.0.1:6379> lrange my 0 -1
        1) "two"
        2) "four"
    
        -- Rpop 命令用于移除最后一个元素,并返回该元素.
        127.0.0.1:6379> lrange my 0 -1
        1) "two"
        2) "four"
        127.0.0.1:6379> rpop my
        "four" -- 移除最后一个元素
        127.0.0.1:6379> lrange my 0 -1
        1) "two"
        
    其它:    
    --Rpoplpush 命令用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。
    --Rpush 命令用于将一个或多个值插入到列表的尾部(最右边)。上面有单个元素添加,还可以是多个元素添加,这里不在演示。
    --Rpushx 命令用于将一个或多个值插入到已存在的列表尾部(最右边)

      

  • 相关阅读:
    错误:Error:未定义标识符"_TCHAR"
    C#中DateTime应用
    随机打乱数组元素
    C++中的运算符重载
    C#中的运算符重载
    C#访问修饰符
    VS2010中将当前选定项目做为启动项
    VS2010 ctrl+F5闪退解决方法
    IntelliSense: 应输入声明的解决方案
    C++数据类型范围
  • 原文地址:https://www.cnblogs.com/MrHSR/p/9964738.html
Copyright © 2011-2022 走看看