List(列表)
Redis的列表是双向链表的一种,所以他的插入和删除的速度非常快,时间复杂度为O(1),但是索引的时间很慢,为O(N)。双向链表支持双向遍历,当列表的最后一个元素被删除之后,该数据结构被自动删除,内存被回收。
Redis的List可以当做双端队列来使用。
基本操作
LPUSH/RPUSH
从左边、右边插入数据
LPUSHX/RPUSHX
从左边、右边插入数据当数据不存在时,什么也不做
LPOP/RPOP
从左边右边弹出数据
RPOPLPUSH
在一个原子操作内,将Alist的最右侧弹出并返回给客户端,再将钙元素插入到Blist的头部
LRANGE
返回列表 key 中指定区间内的元素,区间以偏移量 start 和 stop 指定。
127.0.0.1:6379> lpush cur 1
(integer) 1
127.0.0.1:6379> lpush cur 2
(integer) 2
127.0.0.1:6379> lpush cur 3
(integer) 3
127.0.0.1:6379> lrange cur 1 3
1) "2"
2) "1"
127.0.0.1:6379> lrange cur 0 3
1) "3"
2) "2"
3) "1"
127.0.0.1:6379> lrange cur 0 4
1) "3"
2) "2"
3) "1"
127.0.0.1:6379> lpop cur
"3"
127.0.0.1:6379> lrange cur 0 4
1) "2"
2) "1"
LREM
根据参数 count 的值,移除列表中与参数 value 相等的元素。
count 的值可以是以下几种:
- count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count 。
- count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值。
- count = 0 : 移除表中所有与 value 相等的值。
127.0.0.1:6379> lrange cur 0 -1
1) "2"
2) "1"
3) "3"
4) "4"
5) "5"
6) "5"
7) "5"
127.0.0.1:6379> lrem cur 2 5
(integer) 2
127.0.0.1:6379> lrange cur 0 -1
1) "2"
2) "1"
3) "3"
4) "4"
5) "5"
LTRIM
对list进行裁剪
127.0.0.1:6379> lrange cur 0 -1
1) "2"
2) "1"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> LTRIM cur 2 4 # 只保留位置2-4的元素
OK
127.0.0.1:6379> lrange cur 0 -1
1) "3"
2) "4"
3) "5"
LINDEX
根据下表返回元素
LINSERT
将待插入的值插入到指定值的前或后
LLEN key
返回列表的长度
127.0.0.1:6379> lrange cur 0 -1
1) "3"
2) "4"
3) "5"
127.0.0.1:6379> lindex cur 2
"5"
127.0.0.1:6379> linsert cur after 5 6
(integer) 4
127.0.0.1:6379> lrange cur 0 -1
1) "3"
2) "4"
3) "5"
4) "6"
127.0.0.1:6379> LLEN cur
(integer) 4