• Redis常用操作-------List(列表)


    1.BLPOP key [key ...] timeout

    BLPOP 是列表的阻塞式(blocking)弹出原语。

    它是 LPOP 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BLPOP 命令阻塞,直到等待超时或发现可弹出元素为止。

    当给定多个 key 参数时,按参数 key 的先后顺序依次检查各个列表,弹出第一个非空列表的头元素。

    非阻塞行为

    当 BLPOP 被调用时,如果给定 key 内至少有一个非空列表,那么弹出遇到的第一个非空列表的头元素,并和被弹出元素所属的列表的名字一起,组成结果返回给调用者。

    当存在多个给定 key 时, BLPOP 按给定 key 参数排列的先后顺序,依次检查各个列表。

    假设现在有 job 、 command 和 request 三个列表,其中 job 不存在, command 和 request 都持有非空列表。考虑以下命令:

    BLPOP job command request 0

    BLPOP 保证返回的元素来自 command ,因为它是按”查找 job -> 查找 command -> 查找 request “这样的顺序,第一个找到的非空列表。

     
    redis> DEL job command request           # 确保key都被删除
    (integer) 0
    
    redis> LPUSH command "update system..."  # 为command列表增加一个值
    (integer) 1
    
    redis> LPUSH request "visit page"        # 为request列表增加一个值
    (integer) 1
    
    redis> BLPOP job command request 0       # job 列表为空,被跳过,紧接着 command 列表的第一个元素被弹出。
    1) "command"                             # 弹出元素所属的列表
    2) "update system..."                    # 弹出元素所属的值

    阻塞行为

    如果所有给定 key 都不存在或包含空列表,那么 BLPOP 命令将阻塞连接,直到等待超时,或有另一个客户端对给定 key 的任意一个执行 LPUSH 或 RPUSH 命令为止。

    超时参数 timeout 接受一个以秒为单位的数字作为值。超时参数设为 0 表示阻塞时间可以无限期延长(block indefinitely) 。

    相同的key被多个客户端同时阻塞

    相同的 key 可以被多个客户端同时阻塞。

    不同的客户端被放进一个队列中,按『先阻塞先服务』(first-BLPOP,first-served)的顺序为 key 执行 BLPOP 命令。

    2.BRPOP key [key ...] timeout

    BRPOP 是列表的阻塞式(blocking)弹出原语。

    它是 RPOP 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BRPOP 命令阻塞,直到等待超时或发现可弹出元素为止。

    当给定多个 key 参数时,按参数 key 的先后顺序依次检查各个列表,弹出第一个非空列表的尾部元素。

    关于阻塞操作的更多信息,请查看 BLPOP 命令, BRPOP 除了弹出元素的位置和 BLPOP 不同之外,其他表现一致。

    可用版本:
    >= 2.0.0
    时间复杂度:
    O(1)
    返回值:
    假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。
    反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。
     
     
     

    3.LINDEX key index

    返回列表 key 中,下标为 index 的元素。

    下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。

    你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

    如果 key 不是列表类型,返回一个错误。

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(N), N 为到达下标 index 过程中经过的元素数量。
    因此,对列表的头元素和尾元素执行 LINDEX 命令,复杂度为O(1)。
    返回值:
    列表中下标为 index 的元素。
    如果 index 参数的值不在列表的区间范围内(out of range),返回 nil 。
     
     
     

    4.LINSERT key BEFORE|AFTER pivot value

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

    当 pivot 不存在于列表 key 时,不执行任何操作。

    当 key 不存在时, key 被视为空列表,不执行任何操作。

    如果 key 不是列表类型,返回一个错误。

    可用版本:
    >= 2.2.0
    时间复杂度:
    O(N), N 为寻找 pivot 过程中经过的元素数量。
    返回值:
    如果命令执行成功,返回插入操作完成之后,列表的长度。
    如果没有找到 pivot ,返回 -1 。
    如果 key 不存在或为空列表,返回 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"
    
    
    # 对一个非空列表插入,查找一个不存在的 pivot
    
    redis> LINSERT mylist BEFORE "go" "let's"
    (integer) -1                                    # 失败
    
    
    # 对一个空列表执行 LINSERT 命令
    
    redis> EXISTS fake_list
    (integer) 0
    
    redis> LINSERT fake_list BEFORE "nono" "gogogog"
    (integer) 0                                      # 失败

    5.LLEN key

    返回列表 key 的长度。

    如果 key 不存在,则 key 被解释为一个空列表,返回 0 .

    如果 key 不是列表类型,返回一个错误。

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(1)
    返回值:
    列表 key 的长度。
     

    6.LPOP key

    移除并返回列表 key 的头元素。

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(1)
    返回值:
    列表的头元素。
    当 key 不存在时,返回 nil 。
     
      

    7.LPUSH key value [value ...]

    将一个或多个值 value 插入到列表 key 的表头

    如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表头: 比如说,对空列表 mylist 执行命令 LPUSH mylist bc ,列表的值将是 a ,这等同于原子性地执行 LPUSH mylist a 、 LPUSH mylist b 和 LPUSH mylist c 三个命令。

    如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。

    当 key 存在但不是列表类型时,返回一个错误。

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

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(1)
    返回值:
    执行 LPUSH 命令后,列表的长度。

    8.LPUSHX key value

    将值 value 插入到列表 key 的表头,当且仅当 key 存在并且是一个列表。

    和 LPUSH 命令相反,当 key 不存在时, LPUSHX 命令什么也不做。

    可用版本:
    >= 2.2.0
    时间复杂度:
    O(1)
    返回值:
    LPUSHX 命令执行之后,表的长度。
    # 对空列表执行 LPUSHX
    
    redis> LLEN greet                       # greet 是一个空列表
    (integer) 0
    
    redis> LPUSHX greet "hello"             # 尝试 LPUSHX,失败,因为列表为空
    (integer) 0
    
    
    # 对非空列表执行 LPUSHX
    
    redis> LPUSH greet "hello"              # 先用 LPUSH 创建一个有一个元素的列表
    (integer) 1
    
    redis> LPUSHX greet "good morning"      # 这次 LPUSHX 执行成功
    (integer) 2
    
    redis> LRANGE greet 0 -1
    1) "good morning"
    2) "hello"
    indexnext |previous |

    9.LRANGE key start stop

    返回列表 key 中指定区间内的元素,区间以偏移量 start 和 stop 指定。

    下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。

    你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

    注意LRANGE命令和编程语言区间函数的区别

    假如你有一个包含一百个元素的列表,对该列表执行 LRANGE list 10 ,结果是一个包含11个元素的列表,这表明 stop 下标也在 LRANGE 命令的取值范围之内(闭区间),这和某些语言的区间函数可能不一致,比如Ruby的 Range.new 、 Array#slice 和Python的 range() 函数。

    超出范围的下标

    超出范围的下标值不会引起错误。

    如果 start 下标比列表的最大下标 end ( LLEN list 减去 1 )还要大,那么 LRANGE 返回一个空列表。

    如果 stop 下标比 end 下标还要大,Redis将 stop 的值设置为 end 。

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(S+N), S 为偏移量 start , N 为指定区间内元素的数量。
    返回值:
    一个列表,包含指定区间内的元素。

    10.LREM key count value

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

    count 的值可以是以下几种:

    • count 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count 。
    • count 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值。
    • count 0 : 移除表中所有与 value 相等的值。
    可用版本:
    >= 1.0.0
    时间复杂度:
    O(N), N 为列表的长度。
    返回值:
    被移除元素的数量。
    因为不存在的 key 被视作空表(empty list),所以当 key 不存在时, LREM 命令总是返回 0 。
     
     

    11.LSET key index value

    将列表 key 下标为 index 的元素的值设置为 value 。

    当 index 参数超出范围,或对一个空列表( key 不存在)进行 LSET 时,返回一个错误。

    关于列表下标的更多信息,请参考 LINDEX 命令。

    可用版本:
    >= 1.0.0
    时间复杂度:
    对头元素或尾元素进行 LSET 操作,复杂度为 O(1)。
    其他情况下,为 O(N), N 为列表的长度。
    返回值:
    操作成功返回 ok ,否则返回错误信息。

    12.LTRIM key start stop

    对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。

    举个例子,执行命令 LTRIM list 2 ,表示只保留列表 list 的前三个元素,其余元素全部删除。

    下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。

    你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

    当 key 不是列表类型时,返回一个错误。

    LTRIM 命令通常和 LPUSH 命令或 RPUSH 命令配合使用,举个例子:

    LPUSH log newest_log
    LTRIM log 0 99

    这个例子模拟了一个日志程序,每次将最新日志 newest_log 放到 log 列表中,并且只保留最新的 100 项。注意当这样使用 LTRIM 命令时,时间复杂度是O(1),因为平均情况下,每次只有一个元素被移除。

    注意LTRIM命令和编程语言区间函数的区别

    假如你有一个包含一百个元素的列表 list ,对该列表执行 LTRIM list 10 ,结果是一个包含11个元素的列表,这表明 stop 下标也在 LTRIM 命令的取值范围之内(闭区间),这和某些语言的区间函数可能不一致,比如Ruby的 Range.new 、 Array#slice 和Python的 range() 函数。

    超出范围的下标

    超出范围的下标值不会引起错误。

    如果 start 下标比列表的最大下标 end ( LLEN list 减去 1 )还要大,或者 start stop , LTRIM 返回一个空列表(因为 LTRIM 已经将整个列表清空)。

    如果 stop 下标比 end 下标还要大,Redis将 stop 的值设置为 end 。

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(N), N 为被移除的元素的数量。
    返回值:
    命令执行成功时,返回 ok 。
     
     
     

    13.RPOP key

    移除并返回列表 key 的尾元素。

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(1)
    返回值:
    列表的尾元素。
    当 key 不存在时,返回 nil 。
     
     

    14.RPUSH key value [value ...]

    将一个或多个值 value 插入到列表 key 的表尾(最右边)。

    如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表尾:比如对一个空列表 mylist 执行 RPUSH mylist c ,得出的结果列表为 c ,等同于执行命令 RPUSH mylist a 、 RPUSH mylist b 、 RPUSH mylist c 。

    如果 key 不存在,一个空列表会被创建并执行 RPUSH 操作。

    当 key 存在但不是列表类型时,返回一个错误。

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

    可用版本:
    >= 1.0.0
    时间复杂度:
    O(1)
    返回值:
    执行 RPUSH 操作后,表的长度。
     

    15.RPUSHX key value

    将值 value 插入到列表 key 的表尾,当且仅当 key 存在并且是一个列表。

    和 RPUSH 命令相反,当 key 不存在时, RPUSHX 命令什么也不做。

    可用版本:
    >= 2.2.0
    时间复杂度:
    O(1)
    返回值:
    RPUSHX 命令执行之后,表的长度。
     
  • 相关阅读:
    mongodb3.6 (四)net 客户端如何连接、访问mongodb集群
    mongodb3.6 副本集(三)mongodb 如何做数据备灾
    winform中如何使用确认对话框
    Centos6.5在线配置安装Java环境与Tomcat环境
    IBatis.Net 下使用SqlBulkCopy 大批量导入数据 问题解决
    【easyui-combobox】下拉菜单自动补全功能,Ajax获取远程数据源
    IDEA创建springboot异常(Failed to load class "org.slf4j.impl.StaticLoggerBinder")
    Elasticsearch6.5安装&&常见问题与答案解释
    JS实现多Div模块拖拽功能
    IView入门练习~CDN模式全局加载JS
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/10200200.html
Copyright © 2020-2023  润新知