[关闭]
@Chiang 2020-01-01T09:36:15.000000Z 字数 5325 阅读 488

Redis 列表(List)

Redis


Redis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)
一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个元素)。

blpop

Redis Blpop 命令移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
如果列表为空,返回一个 nil 。 否则,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。

  1. redis 127.0.0.1:6379> BLPOP list1 100
  2. (nil)
  3. (100.06s)

在以上实例中,操作会被阻塞,如果指定的列表 key list1 存在数据则会返回第一个元素,否则在等待100秒后会返回 nil 。

brpop

Redis Brpop 命令移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。

  1. redis> DEL list1 list2
  2. (integer) 0
  3. redis> RPUSH list1 a b c
  4. (integer) 3
  5. redis> BRPOP list1 list2 0
  6. 1) "list1"
  7. 2) "c"

brpoplpush

Redis Brpoplpush 命令从列表中取出最后一个元素,并插入到另外一个列表的头部; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素的值,第二个元素是等待时长。

  1. # 非空列表
  2. redis> BRPOPLPUSH msg reciver 500
  3. "hello moto" # 弹出元素的值
  4. (3.38s) # 等待时长
  5. redis> LLEN reciver
  6. (integer) 1
  7. redis> LRANGE reciver 0 0
  8. 1) "hello moto"
  9. # 空列表
  10. redis> BRPOPLPUSH msg reciver 1
  11. (nil)
  12. (1.34s)

lindex

Redis Lindex 命令用于通过索引获取列表中的元素。你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
返回列表中下标为指定索引值的元素。 如果指定索引值不在列表的区间范围内,返回 nil 。

  1. redis 127.0.0.1:6379> LPUSH mylist "World"
  2. (integer) 1
  3. redis 127.0.0.1:6379> LPUSH mylist "Hello"
  4. (integer) 2
  5. redis 127.0.0.1:6379> LINDEX mylist 0
  6. "Hello"
  7. redis 127.0.0.1:6379> LINDEX mylist -1
  8. "World"
  9. redis 127.0.0.1:6379> LINDEX mylist 3 # index不在 mylist 的区间范围内
  10. (nil)

LINSERT key BEFORE|AFTER pivot value

Redis Linsert 命令用于在列表的元素前或者后插入元素。当指定元素不存在于列表中时,不执行任何操作。
当列表不存在时,被视为空列表,不执行任何操作。
如果 key 不是列表类型,返回一个错误。
如果命令执行成功,返回插入操作完成之后,列表的长度。 如果没有找到指定元素 ,返回 -1 。 如果 key 不存在或为空列表,返回 0 。

  1. redis> RPUSH mylist "Hello"
  2. (integer) 1
  3. redis> RPUSH mylist "World"
  4. (integer) 2
  5. redis> LINSERT mylist BEFORE "World" "There"
  6. (integer) 3
  7. redis> LRANGE mylist 0 -1
  8. 1) "Hello"
  9. 2) "There"
  10. 3) "World"
  11. redis>

llen

Redis Llen 命令用于返回列表的长度。 如果列表 key 不存在,则 key 被解释为一个空列表,返回 0 。 如果 key 不是列表类型,返回一个错误。

  1. redis 127.0.0.1:6379> RPUSH list1 "foo"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH list1 "bar"
  4. (integer) 2
  5. redis 127.0.0.1:6379> LLEN list1
  6. (integer) 2

lpop

Redis Lpop 命令用于移除并返回列表的第一个元素。
列表的第一个元素。 当列表 key 不存在时,返回 nil 。

  1. redis 127.0.0.1:6379> RPUSH list1 "foo"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH list1 "bar"
  4. (integer) 2
  5. redis 127.0.0.1:6379> LPOP list1
  6. "foo"

lpush

Redis Lpush 命令将一个或多个值插入到列表头部。 如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。 当 key 存在但不是列表类型时,返回一个错误。
执行 LPUSH 命令后,列表的长度。

  1. 127.0.0.1:6379> LPUSH list1 "foo"
  2. (integer) 1
  3. 127.0.0.1:6379> LPUSH list1 "bar"
  4. (integer) 2
  5. 127.0.0.1:6379> LRANGE list1 0 -1
  6. 1) "bar"
  7. 2) "foo"

lpushx

Redis Lpushx 将一个值插入到已存在的列表头部,列表不存在时操作无效。LPUSHX 命令执行之后,列表的长度。

  1. 127.0.0.1:6379> LPUSH list1 "foo"
  2. (integer) 1
  3. 127.0.0.1:6379> LPUSHX list1 "bar"
  4. (integer) 2
  5. 127.0.0.1:6379> LPUSHX list2 "bar"
  6. (integer) 0
  7. 127.0.0.1:6379> LRANGE list1 0 -1
  8. 1) "bar"
  9. 2) "foo"

lrange

Redis Lrange 返回列表中指定区间内的元素,区间以偏移量 START 和 END 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
一个列表,包含指定区间内的元素。

  1. redis> RPUSH mylist "one"
  2. (integer) 1
  3. redis> RPUSH mylist "two"
  4. (integer) 2
  5. redis> RPUSH mylist "three"
  6. (integer) 3
  7. redis> LRANGE mylist 0 0
  8. 1) "one"
  9. redis> LRANGE mylist -3 2
  10. 1) "one"
  11. 2) "two"
  12. 3) "three"
  13. redis> LRANGE mylist -100 100
  14. 1) "one"
  15. 2) "two"
  16. 3) "three"
  17. redis> LRANGE mylist 5 10
  18. (empty list or set)
  19. redis>

lrem

Redis Lrem 根据参数 COUNT 的值,移除列表中与参数 VALUE 相等的元素。
COUNT 的值可以是以下几种:
count > 0 : 从表头开始向表尾搜索,移除与 VALUE 相等的元素,数量为 COUNT 。
count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的元素,数量为 COUNT 的绝对值。
count = 0 : 移除表中所有与 VALUE 相等的值。
返回被移除元素的数量。 列表不存在时返回 0 。

  1. redis> RPUSH mylist "hello"
  2. (integer) 1
  3. redis> RPUSH mylist "hello"
  4. (integer) 2
  5. redis> RPUSH mylist "foo"
  6. (integer) 3
  7. redis> RPUSH mylist "hello"
  8. (integer) 4
  9. redis> LREM mylist -2 "hello"
  10. (integer) 2
  11. redis> LRANGE mylist 0 -1
  12. 1) "hello"
  13. 2) "foo"
  14. redis>

lset

Redis Lset 通过索引来设置元素的值。
当索引参数超出范围,或对一个空列表进行 LSET 时,返回一个错误。
操作成功返回 ok ,否则返回错误信息。

  1. redis 127.0.0.1:6379> RPUSH mylist "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH mylist "hello"
  4. (integer) 2
  5. redis 127.0.0.1:6379> RPUSH mylist "foo"
  6. (integer) 3
  7. redis 127.0.0.1:6379> RPUSH mylist "hello"
  8. (integer) 4
  9. redis 127.0.0.1:6379> LSET mylist 0 "bar"
  10. OK
  11. redis 127.0.0.1:6379> LRANGE mylist 0 -1
  12. 1: "bar"
  13. 2) "hello"
  14. 3) "foo"
  15. 4) "hello"

ltrim

Redis Ltrim 对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
下标 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
命令执行成功时,返回 ok 。

  1. redis 127.0.0.1:6379> RPUSH mylist "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH mylist "hello"
  4. (integer) 2
  5. redis 127.0.0.1:6379> RPUSH mylist "foo"
  6. (integer) 3
  7. redis 127.0.0.1:6379> RPUSH mylist "bar"
  8. (integer) 4
  9. redis 127.0.0.1:6379> LTRIM mylist 1 -1
  10. OK
  11. redis 127.0.0.1:6379> LRANGE mylist 0 -1
  12. 1) "hello"
  13. 2) "foo"
  14. 3) "bar"

rpop

Redis Rpop 命令用于移除列表的最后一个元素,返回值为移除的元素。
返回被移除的元素。
当列表不存在时,返回 nil 。

  1. redis> RPUSH mylist "one"
  2. (integer) 1
  3. redis> RPUSH mylist "two"
  4. (integer) 2
  5. redis> RPUSH mylist "three"
  6. (integer) 3
  7. redis> RPOP mylist
  8. "three"
  9. redis> LRANGE mylist 0 -1
  10. 1) "one"
  11. 2) "two"
  12. redis>

rpoplpush

Redis Rpoplpush 命令用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。
被弹出的元素。

  1. redis 127.0.0.1:6379> RPUSH mylist "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH mylist "foo"
  4. (integer) 2
  5. redis 127.0.0.1:6379> RPUSH mylist "bar"
  6. (integer) 3
  7. redis 127.0.0.1:6379> RPOPLPUSH mylist myotherlist
  8. "bar"
  9. redis 127.0.0.1:6379> LRANGE mylist 0 -1
  10. 1) "hello"
  11. 2) "foo"

rpush

Redis Rpush 命令用于将一个或多个值插入到列表的尾部(最右边)。
如果列表不存在,一个空列表会被创建并执行 RPUSH 操作。 当列表存在但不是列表类型时,返回一个错误。
执行 RPUSH 操作后,列表的长度。

  1. redis 127.0.0.1:6379> RPUSH mylist "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH mylist "foo"
  4. (integer) 2
  5. redis 127.0.0.1:6379> RPUSH mylist "bar"
  6. (integer) 3
  7. redis 127.0.0.1:6379> LRANGE mylist 0 -1
  8. 1) "hello"
  9. 2) "foo"
  10. 3) "bar"

rpushx

Redis Rpushx 命令用于将一个值插入到已存在的列表尾部(最右边)。如果列表不存在,操作无效。
执行 Rpushx 操作后,列表的长度。

  1. redis 127.0.0.1:6379> RPUSH mylist "hello"
  2. (integer) 1
  3. redis 127.0.0.1:6379> RPUSH mylist "foo"
  4. (integer) 2
  5. redis 127.0.0.1:6379> RPUSHX mylist2 "bar"
  6. (integer) 0
  7. redis 127.0.0.1:6379> LRANGE mylist 0 -1
  8. 1) "hello"
  9. 2) "foo"

参考资料:
Redis 列表(List)

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注