零基础学习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命名可以指定查询的范围区间

相关推荐
镜舟科技17 分钟前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend1 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence4 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月1 天前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户3169353811831 天前
MySQL服务无法启动问题解决全记录
数据库