Redis系列-存储篇list主要操作命令
Redis系列-存储篇list主要操作命令小结
在总结list之前,先要弄明白几个跟list相关的概念:
列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出。
表头元素:列表最左端第一个元素。
表尾元素:列表最右端的最后一个元素。不包含任何元素的列表成为空列表。
1)新增
a)lpush
语法:lpush key value[value]
解释:把一个或多个元素插入表头。如果是多个value时,按照从左到右的次序插。返回插入元素的个数
[root@xsf001 ~]# redis-cli
redis 127.0.0.1:6379> lpush lst.user zhangsan #插入一个元素
(integer) 1
redis 127.0.0.1:6379> lpush lst.user zhangsan lisi #插入多个元素,list中允许插入重复的元素
(integer) 3
b)lpushx
语法:lpushx key value
解释:插入一个表头元素,当且仅当列表key存在时,才能插入。返回列表中元素的个数
redis 127.0.0.1:6379> lpushx lst.user wangwu #列表存在
(integer) 4
redis 127.0.0.1:6379> lpushx lst.tech wangwu #列表不存在,不插入
(integer) 0
c)rpush
语法:rpush key [value]
解释:将一个或多个值插入到队列的队尾。多值时,从左到右依次添加。返回列表中元素个数
redis 127.0.0.1:6379> rpush lst.user ls005 #列表存在
(integer) 5
redis 127.0.0.1:6379> rpush lst.tech tec01 tec02 tec03 #列表不存在
(integer) 3
d) rpushx
语法:rpushx key value
解释:讲值插入到列表队尾,当且仅当列表key存在时,才添加。返回列表元素个数
redis 127.0.0.1:6379> rpushx lst.tech tec04 #key 存在
(integer) 4
redis 127.0.0.1:6379> rpushx lst.sub englist #key 不存在
(integer) 0
e)linsert
语法:linsert key before|after pivot value
解释:将值插入到pivot的前面或后面。返回列表元素个数。如果参照点pivot不存在不插入。如果有多个pivot,以离表头最近的为准
redis 127.0.0.1:6379> linsert lst.tech after tec04 tec06 #后面插
(integer) 5
redis 127.0.0.1:6379> linsert lst.tech before tec06 tec05 #前面插
(integer) 6
redis 127.0.0.1:6379> linsert lst.tech before tec08 tec07 #参照点不存在,不插
(integer) -1
redis 127.0.0.1:6379> linsert lst.user after zhangsan zhangsan01 #列表中有多个pivot,以从左到右的第一个为准
(integer) 6
2)查询
a)lindex
语法:lindex key index
解释:通过索引index获取列表的元素。 index>=0时, 0 表头,1 第二个元素,依次类推;index<0时,-1,表尾,-2倒数第二个元素,依次类推
redis 127.0.0.1:6379> lindex lst.user 0 #表头
"wangwu"
redis 127.0.0.1:6379> lindex lst.user -1 #表尾
"ls005"
redis 127.0.0.1:6379> lindex lst.user 2 #第三个元素
"zhangsan"
redis 127.0.0.1:6379> lindex lst.user -2 #倒数第二个元素
"zhangsan"
b)lrange
语法:lrange key start stop
解释:获取指定开始和结束范围的一些列元素。0:表头,-1:表尾。如果stop指定的元素在start的左边,返回空列表
redis 127.0.0.1:6379> lrange lst.user 0 -1 #返回所有
1) "wangwu"
2) "lisi"
3) "zhangsan"
4) "zhangsan01"
5) "zhangsan"
6) "ls005"
redis 127.0.0.1:6379> lrange lst.user -1 0 #返回空
(empty list or set)
redis 127.0.0.1:6379> lrange lst.user 1 2 #返回多个
1) "lisi"
2) "zhangsan"
redis 127.0.0.1:6379> lrange lst.user 1 1 #返回一个元素
1) "lisi"
3)修改
lset
语法:lset key index value
解释:设置列表指定索引的值,如果指定索引不存在则报错
redis 127.0.0.1:6379> lset lst.user 2 zhangsan1 #设置第三个元素为zhangsan1
OK
redis 127.0.0.1:6379> lrange lst.user 0 -1
1) "wangwu"
2) "lisi"
3) "zhangsan1"
4) "zhangsan01"
5) "zhangsan"
6) "ls005"
redis 127.0.0.1:6379> lset lst.user 6 ls006 #指定索引不存在
(error) ERR index out of range
4)删除
a)ltrim
语法:ltrim key start stop
解释:保留指定区域的元素,其他元素全部删除
redis 127.0.0.1:6379> ltrim lst.user 0 -2
OK
redis 127.0.0.1:6379> lrange lst.user 0 -1
1) "wangwu"
2) "lisi"
3) "zhangsan1"
4) "zhangsan01"
5) "zhangsan"
b)lrem
语法:lrem key count value
解释:移除等于value的元素,当count>0时,从表头开始查找,移除count个;当count=0时,从表头开始查找,移除所有等于value的;当count<0时,从表尾开始查找,移除|count| 个。
redis 127.0.0.1:6379> lrange lst.user 0 -1
1) "zhangsan"
2) "wangwu"
3) "lisi"
4) "zhangsan1"
5) "zhangsan01"
6) "zhangsan"
7) "lisi"
8) "zhangsan"
9) "lisi"
10) "zhangsan"
redis 127.0.0.1:6379> lrem lst.user 2 zhangsan #移除前两个zhangsan
(integer) 2
redis 127.0.0.1:6379> lrange lst.user 0 -1
1) "wangwu"
2) "lisi"
3) "zhangsan1"
4) "zhangsan01"
5) "lisi"
6) "zhangsan"
7) "lisi"
8) "zhangsan"
redis 127.0.0.1:6379> lrange lst.user -1 zhangsan #移除最后一个zhangsan
(empty list or set)
redis 127.0.0.1:6379> lrange lst.user 0 -1
1) "wangwu"
2) "lisi"
3) "zhangsan1"
4) "zhangsan01"
5) "lisi"
6) "zhangsan"
7) "lisi"
redis 127.0.0.1:6379> lrem lst.user 0 lisi #移除所有lisi
(integer) 3
redis 127.0.0.1:6379> lrange lst.user 0 -1
1) "wangwu"
2) "zhangsan1"
3) "zhangsan01"
4) "zhangsan"
redis 127.0.0.1:6379>
c)rpop
语法:rpop key
解释:移除并返回表尾元素
redis 127.0.0.1:6379> rpop lst.user
"zhangsan"
d)lpop
语法:lpop key
解释:移除并返回表尾元素
redis 127.0.0.1:6379> lpop lst.user
"wangwu"
5)其他
a)llen
语法:llen key
解释:获取列表长度
redis 127.0.0.1:6379> llen lst.user
(integer) 2
Redis系列-存储篇list主要操作命令的更多相关文章
- Redis系列-存储篇string主要操作命令
Redis系列-存储篇string主要操作命令 通过上两篇的介绍,我们的redis服务器基本跑起来.db都具有最基本的CRUD功能,我们沿着这个脉络,开始学习redis丰富的数据结构之旅,当然先从最简 ...
- Redis系列-存储篇sorted set主要操作命令
Redis系列-存储篇sorted set主要操作函数小结 redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sort ...
- Redis系列-存储篇hash主要操作函数小结
阳光透过玻璃,洒在身上,一杯暖茶在手,说不尽的安逸自得,让我有种想再写篇blog的冲动.上篇主要谈了string,这里谈谈hash吧!hash是一些列key value(field value)的映射 ...
- Redis系列-存储篇string主要操作函数小结
通过上两篇的介绍,我们的redis服务器基本跑起来.db都具有最基本的CRUD功能,我们沿着这个脉络,开始学习redis丰富的数据结构之旅,当然先从最简单且常用的string开始. 1.新增 a)se ...
- Redis系列-存储篇sorted set主要操作函数小结
redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sorted set的常用函数: 1)insert a) zadd ...
- Redis系列-存储篇set主要操作函数小结
最近,总是以“太忙“为借口,很久没有blog了,凡事贵在恒,希望我能够坚持不懈,毕竟在blog的时候,也能提升自己.废话不说了,直奔主题”set“ redis set 是string类型对象的无序集合 ...
- Redis系列-存储篇list主要操作函数小结
在总结list之前,先要弄明白几个跟list相关的概念: 列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出. 表头元素:列表最左端第一个元素. 表尾元素:列表最右端的 ...
- Redis系列-存储篇list主要操作函数小结(转)
在总结list之前,先要弄明白几个跟list相关的概念: 列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出. 表头元素:列表最左端第一个元素. 表尾元素:列表最右端的 ...
- Redis系列-存储hash主要操作命令
Redis系列-存储篇hash主要操作函数小结 hash是一些列key value(field value)的映射表.常常用其存储一些对象实例.相对于把一个对象的各个字段存储为string,存储为ha ...
随机推荐
- Apache 低版本不支持 WebSocket
Apache 低版本不支持 WebSocket Apache HTTP Server Version 2.4 Apache Module mod_proxy_wstunnel https://http ...
- js navigator.wakeLock 保持屏幕唤醒状态
let lock; btn.addEventListener("click", async () => { try { if (lock) { lock.release(); ...
- TYLER ADAMS BRADBERRY:人到中年,要学会戒掉这三点
在一些国家的一些人当中,总会出现这样一个问题"中年危机".而到了中年,人与人间的差距似乎也变得越来越大.有人说,人到中年,是一个门槛,有的人迈过去了,有的人没迈过去.但是,其实实话 ...
- VAST二月上线交易所,打通NGK各大币种之间通道!
1月20日,管理着超过8.7万亿美元资产的全球最大资产管理公司贝莱德似乎已批准其旗下两个相关基金--贝莱德全球分配基金公司和贝莱德基金投资比特币期货.提交给美国证券交易委员会的招股说明书文件显示,贝莱 ...
- socket通信框架——boost asio
boost asio是一个封装了基本socket的跨平台通信框架.它支持异步访问,并支持tcp的自动封闭控制等操作. 一个简单的通信协议可以为: header body body长 数据 通过boos ...
- 随手一记,关于Java日期时间格式化
在Java中,我们大多数情况下格式化日期都是使用simpleDateFormat,比如把一个日期格式化成:2019-12-31的形式,我们一般定义模板为:yyyy-MM-dd的形式. 我们需要注意的是 ...
- VMware安装centos.6.8无法访问主机的问题
安装步骤 点击下一步,如下图: 接上图: 接上图: 接上图 接上图: 接上图: 接上图: 接上图 接上图: 接上图: 接上图: 接上图: 接上图: 接上图: 点击 完成: 启动虚拟机进行安装: 发现报 ...
- Sqoop 数据迁移工具
Sqoop 数据迁移工具 sqoop : SQL to hadOOP 两个功能: 1. RDB 向HDFS导入 2. HDFS向RDB导入 注:拷贝mysql-connector.jar 和 json ...
- HBase ——Shell操作
HBase --Shell操作 Q:你觉得HBase是什么? A:一种结构化的分布式数据存储系统,它基于列来存储数据. 基于HBase,可以实现以廉价PC机器集群存储海量数据的分布式数据库的解决方案. ...
- Spring-02 第一个Spring程序
Spring-02 第一个Spring程序 第一个Spring程序 1.导入依赖 <dependency> <groupId>org.springframework</g ...