redis列表数据类型---list
一、概述
- redis列表是简单的字符串列表,按照插入顺序排序
- 可以添加一个元素到列表的头部(左边)或者尾部(右边)
- 一个列表最多可以包含2^32-1个元素(每个列表超过40亿个元素)。
二、redis列表类型键的设置
- 命令名称:lpush
- 语法:lpush key value [value……]
- 功能:
- 1)将一个或多个值value插入到列表key的表头。
- 2)如果多个value值,那么各个value值按从左到右的顺序依次插入到表头。
- 3)操作为原子性操作,如果key不存在,一个空列表会被创建并执行lpush操作。
- 返回值:
- 1)执行lpush命令后,列表的长度;如果key不是列表,返回一个错误
- 命令名称:lpushx
- 语法:lpushx key value
- 功能:
- 1)将值value插入到列表key的表头,当且仅当key存在并且是一个列表。
- 2)和lpush命令相反,当key不存在时,lpushx命令什么也不做。
- 返回值:
- 1)执行lpushx命令后,列表的长度
- 命令名称:linsert
- 语法:linsert key BEFORE|AFTER pivot value
- 功能:
- 1)将值value插入到列表key当中,位于值pivot之前或之后。
- 2)当pivot不存在于列表key时,不执行任何操作。
- 3)当key不存在时,key被视为空列表,不执行任何操作。
- 返回值:
- 1)如果命令执行成功,返回插入操作完成之后,列表的长度;
- 2)如果没有找到pivot,返回-1;
- 3)如果key不存在或为空列表,返回0
- 命令名称:lset
- 语法:lset key index value
- 功能:
- 1)将列表key下标为index的元素的值设置为value。
- 2)当index参数超出范围,或对一个空列表(key不存在)进行lset时,返回一个错误。
- 3)当key不存在时,key被视为空列表,不执行任何操作。
- 返回值:
- 1)操作成功返回ok,否则返回错误信息
- 命令名称:rpush
- 语法:rpush key value [value……]
- 功能:
- 1)将一个或多个值value插入到列表key的尾部。
- 2)如果多个value值,那么各个value值按从左到右的顺序依次插入到表尾。
- 3)操作为原子性操作,如果key不存在,一个空列表会被创建并执行rpush操作。
- 返回值:
- 1)执行rpush命令后,列表的长度;
- 2)如果key不是列表,返回一个错误
- 命令名称:rpushx
- 语法:rpush key value
- 功能:
- 1)将值value插入到列表key的表头,当且仅当key存在并且是一个列表。
- 2)和rpush命令相反,当key不存在时,rpushx命令什么也不做。
- 返回值:
- 1)执行rpushx命令后,列表的长度
三、redis列表类型键的查询
- 命令名称:lindex
- 语法:lindex key index
- 功能:
- 1)返回列表key中,下标为index的元素,0为第一个元素,-1为最后一个元素。
- 返回值:
- 1)列表中下标为index的元素。
- 2)如果index参数的值不在列表的区间范围内(out of range),返回nil
- 命令名称:llen
- 语法:llen key
- 功能:
- 1)返回列表key的长度。
- 返回值:
- 1)如果key不存在,则key被解释为一个空列表,返回0。
- 2)列表key的长度。
- 命令名称:lrange
- 语法:lrange key start stop
- 功能:
- 1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。
- 2)下标(index)参数start和stop都以0为底。
- 3)也可以使用负数下标,以-1表示列表的最后一个元素
- 返回值:
- 1)一个列表,包含指定区间内的元素。
- 2)超出范围的下标值不会引起错误
四、redis列表类型键的删除
- 命令名称:lpop
- 语法:lpop key
- 功能:
- 1)移除并返回列表key的头元素
- 返回值:
- 1)列表的头元素。
- 2)当key不存在时,返回nil
- 命令名称:lrem
- 语法:lrem key count value
- 功能:
- 1)根据参数count的值,移除列表中与参数value相等的元素。
- 2)count > 0:从表头开始向表尾搜索,移除与value相等的元素,数量为count;count < 0:从表尾开始向表头搜索,移除与value相等的元素,数量为count的绝对值;count = 0:移除表中所有与value相等的值
- 返回值:
- 1)被移除元素的数量
- 命令名称:ltrim
- 语法:ltrim key start stop
- 功能:
- 1)对一个列表进行修剪(trim),也就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除
- 返回值:
- 1)命令执行成功是,返回OK。
- 命令名称:rpop
- 语法:rpop key
- 功能:
- 1)移除并返回列表key的尾元素
- 返回值:
- 1)列表的尾元素。
- 2)当key不存在时,返回nil
- 命令名称:rpoplpush
- 语法:rpoplpush source destination
- 功能:
- 1)此命令在一个原子时间内,执行以下两个动作:将列表source中的最后一个元素(尾元素)弹出,并返回给客户端;将source弹出的元素插入到列表destination,作为destination列表的头元素
- 返回值:
- 1)被弹出的元素
五、redis列表类型键的阻塞式操作
- 命令名称:blpop
- 语法:blpop key [key……] timeout
- 功能:
- 1)blpop是列表的阻塞式(blocking)弹出原语,lpop命令的阻塞式版本,当给定列表内没有任何元素可供弹出的时候,连接将被blpop命令阻塞,知道等待超时或发现可弹出元素为止
- 返回值:
- 1)假如在指定时间内没有任何元素被弹出,则返回一个nil和等待时长。
- 2)反之,返回一个含有两个元素的列表,第一个元素是被弹出的元素所属的key,第二个元素是被弹出的元素的值
- 命令名称:brpop
- 语法:brpop key [key……] timeout
- 功能:
- 1)brpop除了弹出元素的位置和blpop不同外,其他表现一致
- 返回值:
- 1)假如在指定时间内没有任何元素被弹出,则返回一个nil和等待时长。
- 2)反之,返回一个含有两个元素的列表,第一个元素是被弹出的元素所属的key,第二个元素是被弹出的元素的值
- 命令名称:brpoplpush
- 语法:brpoplpush source destination timeout
- 功能:
- 1)brpoplpush是rpoplpush的阻塞版本,当给定列表source不为空时,brpoplpush的表现和rpoplpush一样。
- 2)当列表source为空时,brpoplpush命令将阻塞连接,直到等待超时,或有另一个客户端对source执行lpush或rpush命令为止。
- 3)超时参数timeout接受一个以秒为单位的数字作为值。超时参数设为0表示阻塞时间可以无限期延长(block indefinitely)
- 返回值:
- 1)假如在指定时间内没有任何元素被弹出,则返回一个nil和等待时长。
- 2)反之,返回一个含有两个元素的列表,第一个元素是被弹出的元素所属的key,第二个元素是被弹出的元素的值