reids学记笔记(五) 列表(lists)常用命令及操作

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类型可以看成是一个线性表,满足线性表的操作.

猜你喜欢

转载自blog.csdn.net/liutao43/article/details/109826589
今日推荐