redis list 链表数据结构

List (链表)

Redis 链表是简单的字符串列表,按照插入顺序排序,在使用时,可以添加一个元素到列表的头部(左边)或者尾部(右边),list 最多可存储 232 - 1 个元素 (4294967295, 每个列表可存储40多亿)。


redis list 常用命令

  • lpush 命令:将一个或多个值插入到列表头部(左), 如果 key 不存在,一个空列表会被创建并执行 lpush 操作,当 key 存在但不是列表类型时,返回一个错误,执行 lpush 操作后,返回列表的长度。
    基本语法
    redis 127.0.0.1:6379> lpush key value [value ...]
    127.0.0.1:6379> lpush key_list foo
    (integer) 1
    127.0.0.1:6379> lpush key_list bar
    (integer) 2
    127.0.0.1:6379> lrange key_list 0 -1
    1) "bar"
    2) "foo"
    
  • rpush 命令:用于将一个或多个值插入到列表的尾部(最右边),如果列表不存在,一个空列表会被创建并执行 rpush 操作,当列表存在但不是列表类型时,返回一个错误,执行 rpush 操作后,返回列表的长度。
    基本语法
    redis 127.0.0.1:6379> rpush key value [value ...]
    redis 127.0.0.1:6379> rpush key_list hello
    (integer) 1
    redis 127.0.0.1:6379> rpush key_list foo
    (integer) 2
    redis 127.0.0.1:6379> rpush key_list "bar"  // 加引号不影响
    (integer) 3
    redis 127.0.0.1:6379> lrange key_list 0 -1
    1) "hello"
    2) "foo"
    3) "bar"
    
  • lpushx 命令:x:exist 将一个值插入到已存在的列表头部,列表不存在时操作无效,lpushx 命令执行之后,返回列表的长度。
    基本语法
    redis 127.0.0.1:6379> lpushx key value [value ...]
    127.0.0.1:6379> lpush key_list foo
    (integer) 1
    127.0.0.1:6379> lpushx key_list bar
    (integer) 2
    127.0.0.1:6379> lpushx key_list_new bar
    (integer) 0
    127.0.0.1:6379> lrange key_list 0 -1
    1) "bar"
    2) "foo"
    
  • rpushx 命令:用于将一个值插入到已存在的列表尾部(最右边),如果列表不存在,操作无效,rpushx 命令执行之后,返回链表的长度。
    基本语法
    redis 127.0.0.1:6379> rpushx key value [value ...]
    127.0.0.1:6379> lpush key_list a
    (integer) 1
    127.0.0.1:6379> rpushx key_list b
    (integer) 2
    127.0.0.1:6379> rpushx key_list_new c
    (integer) 0
    127.0.0.1:6379>lrange key_list 0 -1
    1) a
    2) b
    
  • linsert 命令:在列表的元素前或者后插入元素,当指定元素 value 不存在于链表中时,被视为空列表,不执行任何操作 ,返回 -1。如果命令执行成功,返回插入操作完成之后,列表的长度。 如果 key 不存在或为空列表,返回 0 。如果 key 不是列表类型,返回一个错误。
    基本语法
    redis> linsert key before|after pivot value
    redis> rpush mylist Hello
    (integer) 1
    redis> rpush mylist World
    (integer) 2
    redis> linsert mylist before "World" "my"
    (integer) 3
    redis> lrange mylist 0 -1
    1) "Hello"
    2) "my"
    3) "World" 
    
  • lset 命令:通过索引来设置元素的值。当索引参数超出范围,或对一个空列表进行 LSET 时,返回一个错误。
    基本语法
    redis> lset key index value
    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"
    

  • lrem 命令:rem:remove,根据参数 count 的值,移除链表中与参数 value 相等的元素。
    基本语法
    redis> lrem key count value

    redis> rpush mylist hello
    (integer) 1
    redis> rpush mylist hello
    (integer) 2
    redis> rpush mylist foo
    (integer) 3
    redis> rpush mylist hello
    (integer) 4
    redis> lrem mylist -2 hello  // 从表位向表头搜索与 hello 相同的value,从而越过了 foo
    (integer) 2
    redis> lrange mylist 0 -1
    1) "hello"
    2) "foo" 
    
    count 值 说明:移除与 value 相等的元素
    count > 0 从表头开始向表尾搜索,数量为 count
    count < 0 从表尾开始向表头搜索,数量为 count
    count = 0 移除表中所有与 value 相等的值
  • lpop 命令:用于移除并返回列表的第一个元素,返回值为移除的元素,当 key 不存在时,返回 nil。
    基本语法
    redis 127.0.0.1:6379> lpop key

    redis 127.0.0.1:6379> rpush key_list "foo"
    (integer) 1
    redis 127.0.0.1:6379> rpush key_list "bar"
    (integer) 2
    redis 127.0.0.1:6379> lpop key_list
    "foo"
    
  • blpop 命令:b:block,移出并获取列表的第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止,如果列表为空,返回一个 nil ,否则,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。
    基本语法
    redis 127.0.0.1:6379> blpop key [key ...] timeout

    redis 127.0.0.1:6379> blpop key_none 100  // 操作被阻塞,在等待100秒后会返回 nil
    (nil)
    (100.06s)
    
  • rpop 命令:用于移除并返回列表的最后一个元素,返回值为移除的元素,当 key 不存在时,返回 nil。
    基本语法
    redis 127.0.0.1:6379> rpop key

    redis 127.0.0.1:6379> rpush key_list "foo"
    (integer) 1
    redis 127.0.0.1:6379> rpush key_list "bar"
    (integer) 2
    redis 127.0.0.1:6379> rpop key_list
    "bar"
    
  • brpop 命令:b:block,移出并获取列表的最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止,如果列表为空,返回一个 nil ,否则,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。
    基本语法
    redis 127.0.0.1:6379> brpop key [key ...] timeout

    redis 127.0.0.1:6379> brpop key_none 100  // 操作被阻塞,在等待100秒后会返回 nil
    (nil)
    (100.02s)
    
  • rpoplpush 命令:用于移除链表的最后一个元素,并将该元素添加到另一个链表并返回。该命令执行后,返回被弹出的元素。
    基本语法
    redis 127.0.0.1:6379> rpoplpush key 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"
    
  • brpoplpush 命令:从列表中弹出一个值,将弹出的元素插入到另外一个列表中并返回它; 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素的值,第二个元素是等待时长。
    基本语法
    redis 127.0.0.1:6379> brpoplpush key destination timeout

    // 非空列表
    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)
    

  • lindex 命令:用于通过索引获取列表中的元素,也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推,列表中下标为指定索引值的元素。 如果指定索引值不在列表的区间范围内,返回 nil 。
    基本语法
    redis 127.0.0.1:6379> lindex key index
    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)
    
  • ltrim 命令:对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除,命令执行成功时,返回 ok 。
    基本语法
    redis> ltrim key start stop
    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"
    
  • llen 命令:用于返回链表的长度。 如果列表 key 不存在,则 key 被解释为一个空列表,返回 0 。 如果 key 不是列表类型,返回一个错误。
    基本语法
    redis 127.0.0.1:6379> llen key
    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
    
  • lrange 命令:返回列表中指定区间内的元素,区间以偏移量 start 和 end 指定。 其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
    基本语法
    redis 127.0.0.1:6379> lrange key start stop
    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) 
    

猜你喜欢

转载自blog.csdn.net/qq_43662261/article/details/85572591
今日推荐