zoukankan      html  css  js  c++  java
  • redis 入门之列表

    lpush

    将一个或多个值 value 插入到列表 key 的表头
    如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表头: 比如说,对空列表 mylist 执行命令 LPUSH mylist a b c ,列表的值将是 c b a ,这等同于原子性地执行
    如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。
    当 key 存在但不是列表类型时,返回一个错误。

    # 加入单个元素
    redis> LPUSH languages python
    (integer) 1
    # 加入重复元素
    redis> LPUSH languages python
    (integer) 2
    redis> LRANGE languages 0 -1     # 列表允许重复元素
    1) "python"
    2) "python"
    # 加入多个元素
    redis> LPUSH mylist a b c
    (integer) 3
    redis> LRANGE mylist 0 -1
    1) "c"
    2) "b"
    3) "a"

    lpushx

    将值 value 插入到列表 key 的表头,当且仅当 key 存在并且是一个列表,返回命令执行之后,表的长度。当 key 不存在时, 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"

    rpush

    将一个或多个值 value 插入到列表 key 的表尾(最右边)。返回操作后list的长度
    如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表尾
    如果 key 不存在,一个空列表会被创建并执行 RPUSH 操作。当 key 存在但不是列表类型时,返回一个错误。

    # 添加单个元素
    redis> RPUSH languages c
    (integer) 1
    # 添加重复元素
    redis> RPUSH languages c
    (integer) 2
    redis> LRANGE languages 0 -1 # 列表允许重复元素
    1) "c"
    2) "c"
    # 添加多个元素
    redis> RPUSH mylist a b c
    (integer) 3
    redis> LRANGE mylist 0 -1
    1) "a"
    2) "b"
    3) "c"

    rpushx

    将值 value 插入到列表 key 的表尾,当且仅当 key 存在并且是一个列表。当key不存在时,什么也不做。

    # key不存在
    redis> LLEN greet
    (integer) 0
    redis> RPUSHX greet "hello"     # 对不存在的 key 进行 RPUSHX,PUSH 失败。
    (integer) 0
    # key 存在且是一个非空列表
    redis> RPUSH greet "hi"         # 先用 RPUSH 插入一个元素
    (integer) 1
    redis> RPUSHX greet "hello"     # greet 现在是一个列表类型,RPUSHX 操作成功。
    (integer) 2
    redis> LRANGE greet 0 -1
    1) "hi"
    2) "hello"

    lpop 

    移除并返回列表 key 的头元素。 当 key 不存在时,返回 nil 。

    redis> LLEN course
    (integer) 0
    redis> RPUSH course algorithm001
    (integer) 1
    redis> RPUSH course c++101
    (integer) 2
    redis> LPOP course  # 移除头元素
    "algorithm001"

    rpop

    移除并返回列表 key 的尾元素。 当 key 不存在时,返回 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"

    rpoplpush 

    命令 RPOPLPUSH 在一个原子时间内,执行以下两个动作:
    将列表 source 中的最后一个元素(尾元素)弹出,并返回给客户端。
    将 source 弹出的元素插入到列表 destination ,作为 destination 列表的的头元素。
    如果 source 不存在,值 nil 被返回,并且不执行其他动作。
    如果 source 和 destination 相同,则列表中的表尾元素被移动到表头,并返回该元素,可以把这种特殊情况视作列表的旋转(rotation)操作。

    # source 和 destination 不同
    redis> LRANGE alpha 0 -1         # 查看所有元素
    1) "a"
    2) "b"
    3) "c"
    4) "d"
    redis> RPOPLPUSH alpha reciver   # 执行一次 RPOPLPUSH 看看
    "d"
    redis> LRANGE alpha 0 -1
    1) "a"
    2) "b"
    3) "c"
    redis> LRANGE reciver 0 -1
    1) "d"
    redis> RPOPLPUSH alpha reciver   # 再执行一次,证实 RPOP 和 LPUSH 的位置正确
    "c"
    redis> LRANGE alpha 0 -1
    1) "a"
    2) "b"
    redis> LRANGE reciver 0 -1
    1) "c"
    2) "d"
    # source 和 destination 相同
    redis> LRANGE number 0 -1
    1) "1"
    2) "2"
    3) "3"
    4) "4"
    redis> RPOPLPUSH number number
    "4"
    redis> LRANGE number 0 -1           # 4 被旋转到了表头
    1) "4"
    2) "1"
    3) "2"
    4) "3"
    redis> RPOPLPUSH number number
    "3"
    redis> LRANGE number 0 -1           # 这次是 3 被旋转到了表头
    1) "3"
    2) "4"
    3) "1"
    4) "2"

    lrem

    LREM key count value 根据参数 count 的值,移除列表中与参数 value 相等的元素。
    count 的值可以是以下几种:
    count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count 。
    count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值。
    count = 0 : 移除表中所有与 value 相等的值。
    返回被移除元素的数量。 因为不存在的 key 被视作空表(empty list),所以当 key 不存在时, LREM 命令总是返回 0 。

    # 先创建一个表,内容排列是
    # morning hello morning helllo morning
    redis> LPUSH greet "morning"
    (integer) 1
    redis> LPUSH greet "hello"
    (integer) 2
    redis> LPUSH greet "morning"
    (integer) 3
    redis> LPUSH greet "hello"
    (integer) 4
    redis> LPUSH greet "morning"
    (integer) 5
    redis> LRANGE greet 0 4         # 查看所有元素
    1) "morning"
    2) "hello"
    3) "morning"
    4) "hello"
    5) "morning"
    redis> LREM greet 2 morning     # 移除从表头到表尾,最先发现的两个 morning
    (integer) 2                     # 两个元素被移除
    redis> LLEN greet               # 还剩 3 个元素
    (integer) 3
    redis> LRANGE greet 0 2
    1) "hello"
    2) "hello"
    3) "morning"
    redis> LREM greet -1 morning    # 移除从表尾到表头,第一个 morning
    (integer) 1
    redis> LLEN greet               # 剩下两个元素
    (integer) 2
    redis> LRANGE greet 0 1
    1) "hello"
    2) "hello"
    redis> LREM greet 0 hello      # 移除表中所有 hello
    (integer) 2                    # 两个 hello 被移除
    redis> LLEN greet
    (integer) 0

    llen

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

    # 空列表
    redis> LLEN job
    (integer) 0
    # 非空列表
    redis> LPUSH job "cook food"
    (integer) 1
    redis> LPUSH job "have lunch"
    (integer) 2
    redis> LLEN job
    (integer) 2

    lindex

    返回列表 key 中,下标为 index 的元素。如果 key 不是列表类型,返回一个错误。

    redis> LPUSH mylist "World"
    (integer) 1
    redis> LPUSH mylist "Hello"
    (integer) 2
    redis> LINDEX mylist 0
    "Hello"
    redis> LINDEX mylist -1
    "World"
    redis> LINDEX mylist 3        # index不在 mylist 的区间范围内
    (nil)

    linsert

    LINSERT key BEFORE|AFTER pivot value将值 value 插入到列表 key 当中,位于值 pivot 之前或之后。
    当 pivot 不存在于列表 key 时,不执行任何操作。
    当 key 不存在时, key 被视为空列表,不执行任何操作。
    如果 key 不是列表类型,返回一个错误。

    命令执行成功,返回插入操作完成之后,列表的长度。 如果没有找到 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                                      #

    lset

    LSET key index value将列表 key 下标为 index 的元素的值设置为 value 。
    当 index 参数超出范围,或对一个空列表( key 不存在)进行 LSET 时,返回一个错误。

    # 对空列表(key 不存在)进行 LSET
    redis> EXISTS list
    (integer) 0
    redis> LSET list 0 item
    (error) ERR no such key
    # 对非空列表进行 LSET
    redis> LPUSH job "cook food"
    (integer) 1
    redis> LRANGE job 0 0
    1) "cook food"
    redis> LSET job 0 "play game"
    OK
    redis> LRANGE job  0 0
    1) "play game"
    # index 超出范围
    redis> LLEN list                    # 列表长度为 1
    (integer) 1
    redis> LSET list 3 'out of range'
    (error) ERR index out of range

    lrange

    LRANGE key start stop返回列表 key 中指定区间内的元素,区间以偏移量 start 和 stop 指定。
    下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。
    你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。

    redis> RPUSH fp-language lisp
    (integer) 1
    redis> LRANGE fp-language 0 0
    1) "lisp"
    redis> RPUSH fp-language scheme
    (integer) 2
    redis> LRANGE fp-language 0 1
    1) "lisp"
    2) "scheme"

    ltrim

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

    # 情况 1: 常见情况, start 和 stop 都在列表的索引范围之内
    redis> LRANGE alpha 0 -1       # alpha 是一个包含 5 个字符串的列表
    1) "h"
    2) "e"
    3) "l"
    4) "l"
    5) "o"
    redis> LTRIM alpha 1 -1        # 删除 alpha 列表索引为 0 的元素
    OK
    redis> LRANGE alpha 0 -1       # "h" 被删除了
    1) "e"
    2) "l"
    3) "l"
    4) "o"
    # 情况 2: stop 比列表的最大下标还要大
    redis> LTRIM alpha 1 10086     # 保留 alpha 列表索引 1 至索引 10086 上的元素
    OK
    redis> LRANGE alpha 0 -1       # 只有索引 0 上的元素 "e" 被删除了,其他元素还在
    1) "l"
    2) "l"
    3) "o"
    # 情况 3: start 和 stop 都比列表的最大下标要大,并且 start < stop
    redis> LTRIM alpha 10086 123321
    OK
    redis> LRANGE alpha 0 -1        # 列表被清空
    (empty list or set)
    # 情况 4: start 和 stop 都比列表的最大下标要大,并且 start > stop
    redis> RPUSH new-alpha "h" "e" "l" "l" "o"     # 重新建立一个新列表
    (integer) 5
    redis> LRANGE new-alpha 0 -1
    1) "h"
    2) "e"
    3) "l"
    4) "l"
    5) "o"
    redis> LTRIM new-alpha 123321 10086    # 执行 LTRIM
    OK
    redis> LRANGE new-alpha 0 -1           # 同样被清空
    (empty list or set)

    blpop

    它是 LPOP key 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BLPOP 命令阻塞,直到等待超时或发现可弹出元素为止。
    当给定多个 key 参数时,按参数 key 的先后顺序依次检查各个列表,弹出第一个非空列表的头元素。

    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 列表的第一个元素被弹出。0 表示如果列表都为空会一直阻塞,非0表示阻塞的秒数。
    1) "command"                             # 弹出元素所属的列表
    2) "update system..."                    # 弹出元素所属的值
    
    redis> EXISTS job                # 确保两个 key 都不存在
    (integer) 0
    redis> EXISTS command
    (integer) 0
    
    redis> BLPOP job command 300     # 因为key一开始不存在,所以操作会被阻塞,直到另一客户端对 job 或者 command 列表进行 PUSH 操作。
    1) "job"                         # 这里被 push 的是 job
    2) "do my home work"             # 被弹出的值
    (26.26s)                         # 等待的秒数
    redis> BLPOP job command 5       # 等待超时的情况
    (nil)
    (5.66s)                          # 等待的秒数

    brpop

    它是 RPOP key 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BRPOP 命令阻塞,直到等待超时或发现可弹出元素为止。
    当给定多个 key 参数时,按参数 key 的先后顺序依次检查各个列表,弹出第一个非空列表的尾部元素。

    redis> LLEN course
    (integer) 0
    redis> RPUSH course algorithm001
    (integer) 1
    redis> RPUSH course c++101
    (integer) 2
    redis> BRPOP course 30
    1) "course"             # 被弹出元素所属的列表键
    2) "c++101"             # 被弹出的元素

    brpoplpush

    BRPOPLPUSH 是 RPOPLPUSH source destination 的阻塞版本,当给定列表 source 不为空时, BRPOPLPUSH 的表现和 RPOPLPUSH source destination 一样。
    当列表 source 为空时, BRPOPLPUSH 命令将阻塞连接,直到等待超时,或有另一个客户端对 source 执行 LPUSH key value [value …] 或 RPUSH key value [value …] 命令为止。
    超时参数 timeout 接受一个以秒为单位的数字作为值。超时参数设为 0 表示阻塞时间可以无限期延长(block indefinitely) 。

    # 非空列表
    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)
  • 相关阅读:
    nginx 简单应用
    js判断图片是否存在
    Quartz Cron 生成工具
    c# 读写文件时文件正由另一进程使用,因此该进程无法访问该文件
    SQL Server 将某一列的值拼接成字符串
    EF 里的 join and Group Join
    .net EF Join 关联表分页查询
    IIS 设置文件可下载
    windows 2003 无法安装 .net4.0 windows服务
    NEST 增删改查
  • 原文地址:https://www.cnblogs.com/tigerzhouv587/p/11346631.html
Copyright © 2011-2022 走看看