小技巧:
- clear:清除记录
- Tab:部分提示
- 上下箭头查看历史记录
列表(list)
list类型其实就是一个双向链表。通过push,pop操作从链表的头部或者尾部添加删除元素。
这使得list既可以用作栈,也可以用作队列。
上进上出 :栈 ,特点:数据 先进后出
1.1. List类型
1.1.1. 简介
- Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)
- 类似JAVA中的LinkedList
1.1.2. 命令
赋值语法:
-
LPUSH key value1 [value2] //将一个或多个值插入到列表头部(从左侧添加)
注意:0表示从下标为0开始,-1表示最后一个元素
-
RPUSH key value1 [value2] //在列表中添加一个或多个值(从右侧添加)
-
LPUSHX key value //将一个值插入到已存在的列表头部。如果列表不在,操作无效
-
RPUSHX key value //一个值插入已存在的列表尾部(最右边)。如果列表不在,操作无效。
取值语法:
- LLEN key //获取列表长度
- LINDEX key index //通过索引获取列表中的元素
注意:-1代表最后一个元素,-2代表倒数第二个,以此类推
- LRANGE key start stop //获取列表指定范围内的元素
描述: 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
start: 页大小*(页数-1)
stop : (页大小*页数)-1
删除语法:
-
LPOP key 移出并获取列表的第一个元素(从左侧删除)
-
RPOP key 移除列表的最后一个元素,返回值为移除的元素(从右侧删除)
-
BLPOP key1 [key2 ] timeout
移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 -
实例
redis 127.0.0.1:6379> BLPOP list1 100
在以上实例中,操作会被阻塞,如果指定的列表 key list1 存在数据则会返回第一个元素,否则在等待100秒后会返回 nil 。
BRPOP key1 [key2 ] timeout
移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 -
LTRIM key start stop 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
修改语法:
- LSET key index value 通过索引设置列表元素的值
- LINSERT key BEFORE|AFTER world value 在列表的元素前或者后插入元素
描述:将值 value 插入到列表 key 当中,位于值 world 之前或之后。
高级语法:
- RPOPLPUSH source destination
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
RPOPLPUSH l1 l2 //a1的最后元素移到a2的左侧
RPOPLPUSH l2 l2 //循环列表,将最后元素移到最左侧
- BRPOPLPUSH source destination timeout
从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。