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

相关推荐
TL滕7 分钟前
从0开始学算法——第十二天(KMP算法练习)
笔记·学习·算法
TG:@yunlaoda360 云老大34 分钟前
腾讯云国际站代理商TACO Kit有什么优势呢?
学习·云计算·腾讯云
云和恩墨39 分钟前
MySQL和PostgreSQL谁更适合AI时代?
数据库
数据猿42 分钟前
【金猿人物展】涛思数据创始人、CEO陶建辉:实现AI时代时序数据库向“数据平台”的转型
大数据·数据库·人工智能·时序数据库·涛思数据
当代红领巾43 分钟前
Oracle 表空间扩容
数据库·oracle
小光学长1 小时前
基于ssm的美妆产品推荐系统rah0h134(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring
_果果然1 小时前
数据库、表、字段:理解MySQL的三层结构
数据库·mysql
Leon-Ning Liu1 小时前
Oracle 19c RAC ASM 密码文件恢复方方案二:基于密码文件备份还原
数据库·oracle
间彧1 小时前
TiDB详解与应用实战:分布式数据库的核心原理与最佳实践
数据库
泉城老铁1 小时前
如何用Spring Boot实现分布式锁?
java·redis·后端