Redis是一个开源的,先进的key-value存储,属于非关系型缓存数据库,通常被称为数据结构服务器。redis一共有五种基本的数据类型,String类型、hash类型、list类型以及set(无序集合)和zset(有序集合),本篇文章为大家分享一下List类型使用方法。
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含 232 – 1 个元素 (4294967295, 每个列表超过40亿个元素)
常用命令
赋值
赋值语法:
LPUSH key value1 [value2] :将一个或多个值插入到列表的头部(从左侧添加)
RPUSH key value1 [value2] :在列表中添加一个或多个值(从右侧添加)
LPUSH key value :将一个值插入到已存在的列表的头部,如果列表不存在,操作无效
RPUSH 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 移除列表的最后一个元素,返回值为移除的元素(从右侧移除) 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 sorce destination timeout 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回他;如果列表没有元素会阻塞队列直到等待超时或发现可弹出元素为止;
应用场景
项目中常应用于:1、对数据量大的集合数据删减 2、任务队列
1、对数据量大的集合数据删减
列表数据显示、关注列表、粉丝列表、留言评价等…分页、热点新闻(Top5)等
利用LRANGE还可以很方便的实现分页的功能,在博客系统中,每篇博文的评论也可以存入一个单独的list中;
2、任务队列
list通常用来实现一个消息队列、而且可以确保先后顺序,不比像mysql那样通过ORDER BY来进行排序
任务队列介绍(生产者和消费者模式)
在处理web客户端发送命令请求时,某些操作的执行时间可能会比我们预期的更长一些,通过将待执行任务的相关信息放入队列里面,并在之后对队列进行处理,用户可用推迟执行那些需要一段时间才能完成的操作,这种将工作交给任务处理器来执行的做法被称为任务队列(task queue);
RPOPLPUSH source destination
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !