Redis - list

1. 概述

数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分
需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序
list类型:保存多个数据,底层使用双向链表存储结构实现

2. 基本使用

//赋值语法: 
LPUSH key value1 [value2]  //将一个或多个值插入到列表头部(从左侧添加)
RPUSH key value1 [value2]  //在列表中添加一个或多个值(从右侧添加)
LPUSHX key value   //将一个值插入到已存在的列表头部。如果列表不在,操作无效
RPUSHX key value   //一个值插入已存在的列表尾部(最右边)。如果列表不在,操作无效。

//取值语法: 
LLEN key      //获取列表长度
LINDEX key index   //通过索引获取列表中的元素
LRANGE key start stop  //获取列表指定范围内的元素

//描述: 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。
//其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推
//start:  页大小*(页数-1)  
//stop : (页大小*页数)-1

//删除语法:
LPOP key  //移出并获取列表的第一个元素(从左侧删除)
RPOP key  //移除列表的最后一个元素,返回值为移除的元素(从右侧删除)
lrem key count value //移除指定数据 count是移除几个 value是删除的值

//规定时间内获取并移除数据
BLPOP key1 [key2 ] timeout 
//移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
//实例
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 a1  a2   //a1的最后元素移到a2的左侧
RPOPLPUSH a1  a1  //循环列表,将最后元素移到最左侧

BRPOPLPUSH source destination timeout 
//从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

3. 使用场景

list 应用于具有操作先后顺序的数据控制

  • list中保存的数据都是string类型的,数据总容量是有限的,最多232 - 1 个元素
  • list具有索引的概念,但是操作数据时通常以队列的形式进行入队出队操作,或以栈的形式进行入栈出栈操作
  • 获取全部数据操作结束索引设置为-1
  • list可以对数据进行分页操作,通常第一页的信息来自于list,第2页及更多的信息通过数据库的形式加载
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值