Redis学习(十) 列表(List)
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)
一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
实例
redis 127.0.0.1:6379> LPUSH runoobkey redis (integer) 1 redis 127.0.0.1:6379> LPUSH runoobkey mongodb (integer) 2 redis 127.0.0.1:6379> LPUSH runoobkey mysql (integer) 3 redis 127.0.0.1:6379> LRANGE runoobkey 0 10 1) "mysql" 2) "mongodb" 3) "redis"
在以上实例中我们使用了 LPUSH 将三个值插入了名为 runoobkey 的列表当中。
Redis 列表命令
下表列出了列表相关的基本命令:
| 序号 | 命令及描述 |
|---|---|
| 1 | BLPOP key1 [key2 ] timeout 移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
| 2 | BRPOP key1 [key2 ] timeout 移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
| 3 | BRPOPLPUSH source destination timeout 从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。 |
| 4 | LINDEX key index 通过索引获取列表中的元素 |
| 5 | LINSERT key BEFORE|AFTER pivot value 在列表的元素前或者后插入元素 |
| 6 | LLEN key 获取列表长度 |
| 7 | LPOP key 移出并获取列表的第一个元素 |
| 8 | LPUSH key value1 [value2] 将一个或多个值插入到列表头部 |
| 9 | LPUSHX key value 将一个值插入到已存在的列表头部 |
| 10 | LRANGE key start stop 获取列表指定范围内的元素 |
| 11 | LREM key count value 移除列表元素 |
| 12 | LSET key index value 通过索引设置列表元素的值 |
| 13 | LTRIM key start stop 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。 |
| 14 | RPOP key 移除列表的最后一个元素,返回值为移除的元素。 |
| 15 | RPOPLPUSH source destination 移除列表的最后一个元素,并将该元素添加到另一个列表并返回 |
| 16 | RPUSH key value1 [value2] 在列表中添加一个或多个值 |
| 17 |
RPUSHX key value |
常用命令:
# 放入元素 lpush/rpush names zs ls ww # 遍历 lrange names 0 -1 # key的长度 llen cities # 查看某个角标的元素 lindex cities 2 # 替换元素 lset cities 3 tj # 为已经存在的列表添加值
lpushx cities cq xa zz
# 在某个元素前/后添加元素
linsert cities before bj sz
linsert cities after gz sz
# 移除列表中的元素
lpop/rpop cities 默认为1
# 阻塞式移除元素(可以处理多个)
blpop/brpop cities 5
从cities中弹出元素,如果没有,则阻塞5秒,如果不写,则一直阻塞。
# 从源中弹出,push到目标列表中
rpoplpush/brpoplpush sour dest
# 截取子串
ltrim cities 2 4
应用场景:
value为list类型的应用场景很多,主要是通过构建不通的数据结构来实现相应的业务功能。这里仅对这些数据结构的实现方式进行总结。
1.栈
通过lpush+lpop可以实现栈数据结构效果:先进先出,通过lpush从列表左侧插入数据,通过lpop从列表左侧取出数据。当然,通过rpush+rpop也可以实现相同效果,只不过是列表右侧。
2.队列
通过lpush+lpop可以实现栈数据结构效果:先进先出,通过lpush从列表左侧插入数据,通过lpop从列表左侧取出数据。当然,通过rpush+rpop也可以实现相同效果,只不过是列表右侧。
3.阻塞式消息队列
通过lpop+brpop可以实现阻塞式消息队列效果。作为消息生产者的客户端使用lpush从列表左侧插入数据,作为消息消费者的多个客户端使用brpop阻塞式抢占列表尾部数据进行消费,保证了消费的负载均衡与高可用性。
4.动态有限集合
通过lpush+ltrim可以实现有限集合,通过lpush从列表左侧向列表中添加数据,通过ltrim保持集合的动态有限性。像企业的末位淘汰,学校的重点班等动态管理,都可通过这种动态有限集合来实现。当然,通过rpush+rtrim也可以实现相同效果,只不过操作的方向正好相反。
本文来自博客园,作者:King-DA,转载请注明原文链接:https://www.cnblogs.com/qingmuchuanqi48/articles/12452509.html


浙公网安备 33010602011771号