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