零基础学习Redis(8) -- list类型命令使用

list相当于一个顺序表。

1. list常用命令

1. lpush / rpush

lpush key value1 value2 ...

rpush key value1 value2..

lpush(left push)从左边插入元素,头插;rpush(right push)从右边插入元素,尾插

两者都会返回插入后的列表长度,并且插入一个元素的时间复杂度都是O(1)

2. lrange

lrange key start stop

lrange(list range)查询列表区间的元素,注意是闭区间,支持使用负数下标:

如果区间超出范围会返回区间内存在的元素,不存在元素返回空列表:

3. lpushx / rpushx

lpushx key value1 value2 ...

rpushx key value1 value2..

和lpush / rpush使用方法相同,不过只有列表中存在元素时才会成功

4. lpop / rpop

lpop key [count]

rpop key [count]

lpop(left pop) 头删,rpop(right pop)尾删。

count 代表要删除的数量,不写则默认删除一个,删除后会返回被删除的值:

5. lindex

lindex key index

lindex(list index)查询指定下标的元素,如果下标不存在返回nil,时间复杂度为O(N):

6. linsert

linsert <before | after> pivot element

linsert(list insert)在列表中第一个值为pivot元素的前面或后面插入元素element ,返回插入后列表的长度,时间复杂度为O(N):

7. llen

llen key

llen(list length)查询列表中的元素个数:

8. lrem

lrem key count element

lrem(list remove) 删除列表中的element,当count 等于0删除全部的element,大于0时从左往右删count个,小于0时从右往左删-count个:

9. ltrim

ltrim key start stop

保留start 到 stop区间内的元素:

10. lset

lset key index element

修改index下标下的元素为element,下标存在才能执行成功

11. blpop / brpop

blpop key1 key2 timeout

brpop key1 key2 timeout

功能和lpop / rpop类似,从一个或多个key中头删/尾删一个元素,并且带有阻塞功能,当列表中没有元素时会阻塞等待,直到超时时间或者列表中被添加了元素:

有元素会立即返回,key和对应的数据,超过设置时间则返回nil:

使用blpop和brpop不会阻塞redis线程。

2. 内部编码

前面我们介绍时说的的使用 ziplist 和 linkedList,实际上5.多版本使用的是quicklist,quicklist,本质上还是一个链表,但是每个节点都是一个ziplist,节点的大小可以通过修改redis.conf文件来调整,当某个点大小超过设置大小就会分裂为两个节点:

可以看到默认是 -2 ,通过上面注释可以直到每个节点超过8kb就会分裂

3. 应用场景

  1. 用作数组,存储一些同类的数据,例如一个班级的学生

  2. 用作阻塞队列,使用brpop/blpop/lpush/rpush可以很简单的模拟一个生产者消费者模型

  3. 用于分页查询,使用lrange命名可以指定查询的范围区间

相关推荐
大巨头2 分钟前
sql2008 数据库分页语句
数据库
m0_715575342 分钟前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
sensen_kiss22 分钟前
INT303 Coursework1 爬取影视网站数据(如何爬虫网站数据)
爬虫·python·学习
老邓计算机毕设33 分钟前
SSM智慧社区家政服务系统80q7o(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架
red_redemption1 小时前
自由学习记录(116)
学习
松涛和鸣1 小时前
72、IMX6ULL驱动实战:设备树(DTS/DTB)+ GPIO子系统+Platform总线
linux·服务器·arm开发·数据库·单片机
likangbinlxa2 小时前
【Oracle11g SQL详解】UPDATE 和 DELETE 操作的正确使用
数据库·sql
r i c k2 小时前
数据库系统学习笔记
数据库·笔记·学习
野犬寒鸦2 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
IvorySQL3 小时前
PostgreSQL 分区表的 ALTER TABLE 语句执行机制解析
数据库·postgresql·开源