redis——列表(list)

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

list列表命令:

1、BLPOP list1 [list2] timeout

移出并获取列表的第一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

如果列表为空,返回一个nil。否则,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的list,第二个元素是被弹出元素的值。

2、BRPOP  list1 [list2] timeout

移出并获取列表的最后一个元素,如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

假如在指定时间内没有任何元素被弹出,则返回一个nil和等待时长,反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的list,第二个元素是被弹出元素的值。

3、BRPOPLPUSH source  destination  timeout

从列表中弹出一个值,将弹出的元素插入到另一个列表中并返回它;如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。

假如在指定时间内没有任何元素被弹出,则返回一个nil和等待时长。反之,返回一个含有两个元素的列表,第一个元素是被弹出元素的值,第二个元素是等待时长。

redis> BRPOPLPUSH msg reciver 500
"hello moto"                        # 弹出元素的值
(3.38s)                             # 等待时长

redis> LLEN reciver
(integer) 1

redis> LRANGE reciver 0 0
1) "hello moto"


# 空列表

redis> BRPOPLPUSH msg reciver 1
(nil)
(1.34s)

4、LINDEX list index

通过索引获取列表中的元素,可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

返回列表中下标为指定索引值的元素。如果指定索引值不在列表的区间范围内,返回nil。

redis 127.0.0.1:6379> LPUSH mylist "World"
(integer) 1

redis 127.0.0.1:6379> LPUSH mylist "Hello"
(integer) 2

redis 127.0.0.1:6379> LINDEX mylist 0
"Hello"

redis 127.0.0.1:6379> LINDEX mylist -1
"World"

redis 127.0.0.1:6379> LINDEX mylist 3        # index不在 mylist 的区间范围内
(nil)

5、LINSERT list BEFORE|AFTER pivot value

在列表的元素前或者后插入元素,当指定元素不存在于列表中时,不执行任何操作。

当列表不存在时,被视为空列表,不执行任何操作。如果list不是列表类型,返回一个错误。

将值value插入到列表list当中,位于值pivot之前后之后。

如果命令执行成功,返回插入操作完成之后,列表的长度。如果没有找到指定元素,返回-1。如果list不存在或为空列表,返回0。

redis> RPUSH mylist "Hello"
(integer) 1
redis> RPUSH mylist "World"
(integer) 2
redis> LINSERT mylist BEFORE "World" "There"
(integer) 3
redis> LRANGE mylist 0 -1
1) "Hello"
2) "There"
3) "World"
redis>

6、LLEN  list

获取列表的长度,如果列表list不存在,则list被解释为一个空列表,返回0。如果list不是列表类型,返回一个错误。

redis 127.0.0.1:6379> RPUSH list1 "foo"
(integer) 1
redis 127.0.0.1:6379> RPUSH list1 "bar"
(integer) 2
redis 127.0.0.1:6379> LLEN list1
(integer) 2

7、LPOP list

移出并获取列表的第一个元素,返回列表的第一个元素,当列表list不存在时,返回nil。

redis 127.0.0.1:6379> RPUSH list1 "foo"
(integer) 1
redis 127.0.0.1:6379> RPUSH list1 "bar"
(integer) 2
redis 127.0.0.1:6379> LPOP list1
"foo"

8、LPUSH list value1 [value2]

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

注意:在Redis 2.4版本以前的 LPUSH 命令,都只接受单个 value 值。

127.0.0.1:6379> LPUSH list1 "foo"
(integer) 1
127.0.0.1:6379> LPUSH list1 "bar"
(integer) 2
127.0.0.1:6379> LRANGE list1 0 -1
1) "bar"
2) "foo"

9、LPUSHX list value1 ... valueN

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

127.0.0.1:6379> LPUSH list1 "foo"
(integer) 1
127.0.0.1:6379> LPUSHX list1 "bar"
(integer) 2
127.0.0.1:6379> LPUSHX list2 "bar"
(integer) 0
127.0.0.1:6379> LRANGE list1 0 -1
1) "bar"
2) "foo"

10、LRANGE list start end

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

redis> RPUSH mylist "one"
(integer) 1
redis> RPUSH mylist "two"
(integer) 2
redis> RPUSH mylist "three"
(integer) 3
redis> LRANGE mylist 0 0
1) "one"
redis> LRANGE mylist -3 2
1) "one"
2) "two"
3) "three"
redis> LRANGE mylist -100 100
1) "one"
2) "two"
3) "three"
redis> LRANGE mylist 5 10
(empty list or set)
redis>

11、LREM list count value

lrem根据参数count的值,移除列表中与参数value相等的元素。

count的值可以是以下几种:

    count > 0:从表头开始向表尾搜索,移除与value相等的元素,数量为count。

    count < 0:从表尾开始向表头搜索,移除与value相等的元素,数量为count的绝对值。

    count = 0:移除表中所有与value相等的值。

返回被移除元素的数量,列表不存在时返回0。

redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 4
redis 127.0.0.1:6379> LREM mylist -2 "hello"
(integer) 2

12、LSET list index value

LSET通过索引来设置元素的值。当索引参数超过范围,或对一个空列表进行lset时,返回一个错误。

操作成功返回ok,否则返回错误信息。

redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 4
redis 127.0.0.1:6379> LSET mylist 0 "bar"
OK
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1: "bar"
2) "hello"
3) "foo"
4) "hello"

13、LTRIM list start stop

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

redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 3
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 4
redis 127.0.0.1:6379> LTRIM mylist 1 -1
OK
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"
3) "bar"

14、RPOP list

用于移除并返回列表的最后一个元素,当列表不存在时,返回nil。

redis> RPUSH mylist "one"
(integer) 1
redis> RPUSH mylist "two"
(integer) 2
redis> RPUSH mylist "three"
(integer) 3
redis> RPOP mylist
"three"
redis> LRANGE mylist 0 -1
1) "one"
2) "two"
redis>

15、RPOPLPUSH source destination

用于移除列表的最后一个元素,并将该元素添加到另一个列表并返回。

返回被弹出的元素。

redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 3
redis 127.0.0.1:6379> RPOPLPUSH mylist myotherlist
"bar"
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"

16、RPUSH list value1... valueN

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

注意:在Redis2.4版本之前的RPUSH命令,都只接受单个value值。

redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 2
redis 127.0.0.1:6379> RPUSH mylist "bar"
(integer) 3
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"
3) "bar"

17、RPUSHX list value1...valueN

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

返回执行RPUSHX操作后,列表的长度。

redis 127.0.0.1:6379> RPUSH mylist "hello"
(integer) 1
redis 127.0.0.1:6379> RPUSH mylist "foo"
(integer) 2
redis 127.0.0.1:6379> RPUSHX mylist2 "bar"
(integer) 0
redis 127.0.0.1:6379> LRANGE mylist 0 -1
1) "hello"
2) "foo"

猜你喜欢

转载自my.oschina.net/u/3767248/blog/1811454
今日推荐