Redis 列表(List)常用命令
Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含2^32 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。
list这种数据结构有很多基础数据结构的操作。总体类似于链地址法。
LPUSH key value1 [value2]
将一个或多个值插入到列表头部
RPUSH key value1 [value2]
在列表中添加一个或多个值
LRANGE key start stop
获取列表指定范围内的元素,小技巧:top可以设置为的-1,找不到,就会获取全部范围。
LPOP key
移出并获取列表的第一个元素
RPOP key
移除列表的最后一个元素,返回值为移除的元素。
LINDEX key index
通过索引获取列表中的元素
LLEN key
获取列表长度
LREM key count value
移除列表元素
LTRIM key start stop
对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
RPOPLPUSH source destination
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
LSET key index value
通过索引设置列表元素的值
LINSERT key BEFORE|AFTER pivot value
在列表的元素前或者后插入元素
清空所有数据库
127.0.0.1:6379> FLUSHALL # 晴空数据库所有的值
OK
127.0.0.1:6379> KEYS *
(empty list or set)
案例1
127.0.0.1:6379> LPUSH bigdata hadoop spark flink storm # 从列表的头插入,类似于链表的头插法,也可以看成栈,也可以看成从左边依次插入,看如何理解了
(integer) 4
127.0.0.1:6379> LRANGE bigdata 0 -1 # 获取列表中的值
1) "storm"
2) "flink"
3) "spark"
4) "hadoop"
127.0.0.1:6379> RPUSH comput mapreduce rdd topology # 和LPUSH相反
(integer) 3
127.0.0.1:6379> LRANGE comput 0 -1
1) "mapreduce"
2) "rdd"
3) "topology"
127.0.0.1:6379> LPOP comput # 获取列表头元素
"mapreduce"
127.0.0.1:6379> RPOP comput # 获取列表尾元素
"topology"
127.0.0.1:6379> LINDEX comput 0 # 获取下标中的值,从0开始
"mapreduce"
127.0.0.1:6379> LINDEX comput -1
"rdd"
127.0.0.1:6379> LPUSH comput FLINK STORM SPARKSTREAMING
(integer) 5
127.0.0.1:6379> LPUSH comput mapreduce mapreduce
(integer) 7
127.0.0.1:6379> LREM comput 3 mapreduce # 删除3个value为mapreduce的值
(integer) 3
127.0.0.1:6379> LRANGE comput 0 -1
1) "SPARKSTREAMING"
2) "STORM"
3) "FLINK"
4) "rdd"
127.0.0.1:6379> LTRIM comput 1 2 # 保留相应下标的内容,其余部分剪掉
OK
127.0.0.1:6379> LRANGE comput 0 -1
1) "STORM"
2) "FLINK"
案例2
127.0.0.1:6379> RPOPLPUSH comput comput1 # 移除comput最后一个元素到comput1的第一个位置
"FLINK"
127.0.0.1:6379> RPOPLPUSH comput comput1
"STORM"
127.0.0.1:6379> LRANGE comput 0 -1
(empty list or set)
127.0.0.1:6379> LRANGE comput1 0 -1
1) "STORM"
2) "FLINK"
127.0.0.1:6379> LSET comput1 1 HADOOP
OK
127.0.0.1:6379> LRANGE comput1 0 -1
1) "STORM"
2) "HADOOP"
127.0.0.1:6379> LINSERT comput1 before STORM SPARK # 在STORM之前或者之后插入一个value
(integer) 3
127.0.0.1:6379> LINSERT comput1 before SPARK HERON
(integer) 4
127.0.0.1:6379> LINSERT comput1 after HADOOP HERON
(integer) 5
127.0.0.1:6379> LRANGE comput1 0 -1
1) "HERON"
2) "SPARK"
3) "STORM"
4) "HADOOP"
5) "HERON"
总结
list类型可以看成是一个线性表,满足线性表的操作.