Redis List的基本操作

时间:2025-02-18 09:13:58

Redis List基本操作

在Redis里面,list可以被当做栈,队列,阻塞队列使用

所有的list 命令都是用l开头的,命令不区分大小写

push:把值插入列表

127.0.0.1:6379> keys *
(empty list or set)
127.0.0.1:6379> lpush list one         #将一个值或多个值,插入到列表头部(左部)
(integer) 1
127.0.0.1:6379> lpush list two
(integer) 2
127.0.0.1:6379> lpush list three
(integer) 3
127.0.0.1:6379> lrange list 0 -1		#获取list的值
1) "three"
2) "two"
3) "one"
127.0.0.1:6379> lrange list 0 1         #通过区间获取list的值
1) "three"
2) "two"
#################################################
127.0.0.1:6379> rpush list right		#将一个值或多个值,插入到列表尾部(右部)
(integer) 4
127.0.0.1:6379> lrange list 0 -1
1) "three"
2) "two"
3) "one"
4) "right"

pop:移除列表的值

lindex:通过下标获取值

127.0.0.1:6379> lrange list 0 -1
1) "three"
2) "two"
3) "one"
4) "right"
127.0.0.1:6379> lpop list                  #移除list的第一个元素
"three"
127.0.0.1:6379> rpop list					#移除list的最后一个元素
"right"
127.0.0.1:6379> lrange list 0 -1
1) "two"
2) "one"
127.0.0.1:6379> lindex list 1               #通过下标获取值
"one"
127.0.0.1:6379> lindex list 0
"two"

llen:获取长度

127.0.0.1:6379> lpush list one
(integer) 1
127.0.0.1:6379> lpush list two
(integer) 2
127.0.0.1:6379> lpush list three
(integer) 3
127.0.0.1:6379> llen list					#获取列表的长度
(integer) 3

lrem:移除某个指定的值

127.0.0.1:6379> lrange list 0 -1
1) "three"
2) "three"
3) "two"
4) "one"
127.0.0.1:6379> lrem list 1 three		#移除一个three   1改为2 两个都移除
(integer) 1
127.0.0.1:6379> lrange list 0 -1
1) "three"
2) "two"
3) "one"

lset:将列表中指定下标的值替换为另外一个值,相当于更新,如果没有列表则报错

127.0.0.1:6379> lset list 0 test
(error) ERR no such key
127.0.0.1:6379> lpush list value
(integer) 1
127.0.0.1:6379> lrange list 0 0
1) "value"
127.0.0.1:6379> lset list 0 test          #用test替换list下标为0 的元素
OK
127.0.0.1:6379> lrange list 0 0
1) "test"
127.0.0.1:6379> lset list 1 test1			#不存在下标值也报错
(error) ERR index out of range

linsert:将某个具体的值插入到某个元素前面或后面

127.0.0.1:6379> lrange list 0 -1
1) "test"
127.0.0.1:6379> linsert list after test test1     #before之前
(integer) 2
127.0.0.1:6379> lrange list 0 -1
1) "test"
2) "test1"

总结:

  • 相当于一个链表,左右都可以插入值
  • 在两边插入或改变值,效率最高;改变中间元素,效率稍低一点
  • 通过左右存值和取值,可以当做队列(Lpush Rpop)或栈(Lpush Lpop)使用