Redis数据类型之List列表类型
小技巧:
- 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
 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
- 点赞
- 收藏
- 关注作者
 
            









 
           
评论(0)