Redis系列-存储篇list主要操作函数小结

      1. 在总结list之前,先要弄明白几个跟list相关的概念:

        列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出。

        表头元素:列表最左端第一个元素。

        表尾元素:列表最右端的最后一个元素。不包含任何元素的列表成为空列表。

        1)新增

        a)lpush

        语法:lpush key value[value]

        解释:把一个或多个元素插入表头。如果是多个value时,按照从左到右的次序插。返回插入元素的个数

        [plain] view plaincopy

        1. [[email protected] ~]# redis-cli
        2. redis 127.0.0.1:6379> lpush lst.user zhangsan   #插入一个元素
        3. (integer) 1
        4. redis 127.0.0.1:6379> lpush lst.user zhangsan lisi   #插入多个元素,list中允许插入重复的元素
        5. (integer) 3

        b)lpushx

        语法:lpushx key value

        解释:插入一个表头元素,当且仅当列表key存在时,才能插入。返回列表中元素的个数

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> lpushx lst.user wangwu   #列表存在
        2. (integer) 4
        3. redis 127.0.0.1:6379> lpushx lst.tech wangwu   #列表不存在,不插入
        4. (integer) 0

        c)rpush

        语法:rpush key [value]

        解释:将一个或多个值插入到队列的队尾。多值时,从左到右依次添加。返回列表中元素个数

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> rpush lst.user ls005     #列表存在
        2. (integer) 5
        3. redis 127.0.0.1:6379> rpush lst.tech tec01 tec02 tec03  #列表不存在
        4. (integer) 3

        d) rpushx

        语法:rpushx key value

        解释:讲值插入到列表队尾,当且仅当列表key存在时,才添加。返回列表元素个数

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> rpushx lst.tech tec04  #key 存在
        2. (integer) 4
        3. redis 127.0.0.1:6379> rpushx lst.sub englist #key 不存在
        4. (integer) 0

        e)linsert

        语法:linsert key before|after pivot value

        解释:将值插入到pivot的前面或后面。返回列表元素个数。如果参照点pivot不存在不插入。如果有多个pivot,以离表头最近的为准

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> linsert lst.tech after tec04 tec06  #后面插
        2. (integer) 5
        3. redis 127.0.0.1:6379> linsert lst.tech before tec06 tec05 #前面插
        4. (integer) 6
        5. redis 127.0.0.1:6379> linsert lst.tech before tec08 tec07 #参照点不存在,不插
        6. (integer) -1
        7. redis 127.0.0.1:6379> linsert lst.user after zhangsan zhangsan01  #列表中有多个pivot,以从左到右的第一个为准
        8. (integer) 6

        2)查询

        a)lindex

        语法:lindex key index

        解释:通过索引index获取列表的元素。 index>=0时, 0 表头,1 第二个元素,依次类推;index<0时,-1,表尾,-2倒数第二个元素,依次类推

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> lindex lst.user 0  #表头
        2. "wangwu"
        3. redis 127.0.0.1:6379> lindex lst.user -1 #表尾
        4. "ls005"
        5. redis 127.0.0.1:6379> lindex lst.user 2 #第三个元素
        6. "zhangsan"
        7. redis 127.0.0.1:6379> lindex lst.user -2 #倒数第二个元素
        8. "zhangsan"

        b)lrange

        语法:lrange key start stop

        解释:获取指定开始和结束范围的一些列元素。0:表头,-1:表尾。如果stop指定的元素在start的左边,返回空列表

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> lrange lst.user 0 -1 #返回所有
        2. 1) "wangwu"
        3. 2) "lisi"
        4. 3) "zhangsan"
        5. 4) "zhangsan01"
        6. 5) "zhangsan"
        7. 6) "ls005"
        8. redis 127.0.0.1:6379> lrange lst.user -1 0  #返回空
        9. (empty list or set)
        10. redis 127.0.0.1:6379> lrange lst.user 1 2  #返回多个
        11. 1) "lisi"
        12. 2) "zhangsan"
        13. redis 127.0.0.1:6379> lrange lst.user 1 1   #返回一个元素
        14. 1) "lisi"

        3)修改

        lset

        语法:lset key index value

        解释:设置列表指定索引的值,如果指定索引不存在则报错

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> lset lst.user 2 zhangsan1  #设置第三个元素为zhangsan1
        2. OK
        3. redis 127.0.0.1:6379> lrange lst.user 0 -1
        4. 1) "wangwu"
        5. 2) "lisi"
        6. 3) "zhangsan1"
        7. 4) "zhangsan01"
        8. 5) "zhangsan"
        9. 6) "ls005"
        10. redis 127.0.0.1:6379> lset lst.user 6 ls006  #指定索引不存在
        11. (error) ERR index out of range

        4)删除

        a)ltrim

        语法:ltrim key start stop

        解释:保留指定区域的元素,其他元素全部删除

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> ltrim lst.user 0 -2
        2. OK
        3. redis 127.0.0.1:6379> lrange lst.user 0 -1
        4. 1) "wangwu"
        5. 2) "lisi"
        6. 3) "zhangsan1"
        7. 4) "zhangsan01"
        8. 5) "zhangsan"

        b)lrem

        语法:lrem key count value

        解释:移除等于value的元素,当count>0时,从表头开始查找,移除count个;当count=0时,从表头开始查找,移除所有等于value的;当count<0时,从表尾开始查找,移除|count| 个。

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> lrange lst.user 0 -1
        2. 1) "zhangsan"
        3. 2) "wangwu"
        4. 3) "lisi"
        5. 4) "zhangsan1"
        6. 5) "zhangsan01"
        7. 6) "zhangsan"
        8. 7) "lisi"
        9. 8) "zhangsan"
        10. 9) "lisi"
        11. 10) "zhangsan"
        12. redis 127.0.0.1:6379> lrem lst.user 2 zhangsan #移除前两个zhangsan
        13. (integer) 2
        14. redis 127.0.0.1:6379> lrange lst.user 0 -1
        15. 1) "wangwu"
        16. 2) "lisi"
        17. 3) "zhangsan1"
        18. 4) "zhangsan01"
        19. 5) "lisi"
        20. 6) "zhangsan"
        21. 7) "lisi"
        22. 8) "zhangsan"
        23. redis 127.0.0.1:6379> lrange lst.user -1 zhangsan #移除最后一个zhangsan
        24. (empty list or set)
        25. redis 127.0.0.1:6379> lrange lst.user 0 -1
        26. 1) "wangwu"
        27. 2) "lisi"
        28. 3) "zhangsan1"
        29. 4) "zhangsan01"
        30. 5) "lisi"
        31. 6) "zhangsan"
        32. 7) "lisi"
        33. redis 127.0.0.1:6379> lrem lst.user 0 lisi  #移除所有lisi
        34. (integer) 3
        35. redis 127.0.0.1:6379> lrange lst.user 0 -1
        36. 1) "wangwu"
        37. 2) "zhangsan1"
        38. 3) "zhangsan01"
        39. 4) "zhangsan"
        40. redis 127.0.0.1:6379>

        c)rpop

        语法:rpop key

        解释:移除并返回表尾元素

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> rpop lst.user
        2. "zhangsan"

        d)lpop

        语法:lpop key

        解释:移除并返回表尾元素

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> lpop lst.user
        2. "wangwu"

        5)其他

        a)llen

        语法:llen key

        解释:获取列表长度

        [plain] view plaincopy

        1. redis 127.0.0.1:6379> llen lst.user
        2. (integer) 2

        参考:http://redis.io/commands#list

时间: 2024-10-08 05:06:25

Redis系列-存储篇list主要操作函数小结的相关文章

Redis系列-存储篇hash主要操作函数小结

hash是一些列key value(field value)的映射表.常常用其存储一些对象实例.相对于把一个对象的各个字段存储为string,存储为hash会占用更少的内存.为什么会更省内存呢?需要搞清楚两个配置(hash-max-zipmap-entries和hash-max-zipmap-value)的含义,配置的详细介绍,我打算放在最后的配置优化环节讲. 1)新增 a)hset 语法:hset key field value 解释:设置hash表key中的field的值.如果hash表不存

Redis系列-存储篇list主要操作函数小结(转)

在总结list之前,先要弄明白几个跟list相关的概念: 列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出. 表头元素:列表最左端第一个元素. 表尾元素:列表最右端的最后一个元素.不包含任何元素的列表成为空列表. 1)新增 a)lpush 语法:lpush key value[value] 解释:把一个或多个元素插入表头.如果是多个value时,按照从左到右的次序插.返回插入元素的个数 [plain] view plaincopy [[email protect

Redis系列-存储篇sorted set主要操作命令

Redis系列-存储篇sorted set主要操作函数小结 redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sorted set的常用函数: 1)insert a)zadd 语法:zadd?key score member?[[score member] [score member] ...] 解释:增加一个或多个member[根据score排序]到有序集key中,如果member已经存在,只更新score.返回

Redis系列-存储篇string主要操作命令

Redis系列-存储篇string主要操作命令 通过上两篇的介绍,我们的redis服务器基本跑起来.db都具有最基本的CRUD功能,我们沿着这个脉络,开始学习redis丰富的数据结构之旅,当然先从最简单且常用的string开始. 1.新增 a)set 语法:set key value 解释:把值value赋给key,如果key不存在,新增:否则,更新 [[email protected] ~]# redis-cli redis 127.0.0.1:6379> set user.1.name zh

Redis系列-存储篇sorted set主要操作函数小结

redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sorted set的常用函数: 1)insert a)  zadd 语法:zadd key score member [[score member] [score member] ...] 解释:增加一个或多个member[根据score排序]到有序集key中,如果member已经存在,只更新score.返回增加member个数,不包含已经存在的member [p

python文件和目录操作函数小结

本文主要介绍python文件和目录操作函数小结,主要涉及到os模块和shutil模块的一些方法. python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd()返回指定目录下的所有文件和目录名:os.listdir()函数用来删除一个文件:os.remove()删除多个目录:os.removedirs(r"c:\python")检验给出的路径是否是一个文件:os.path.isf

openssl之BIO系列之6---BIO的IO操作函数

BIO的IO操作函数 ---依据openssl doc/crypto/bio/bio_read.pod翻译和自己的理解写成 (作者:DragonKing Mail:[email protected] 公布于:http://gdwzh.126.com之openssl专业论坛) 这些函数是BIO的基本读写操作函数,包含四个,他们的定义例如以下(openssl/bio.h): int BIO_read(BIO *b, void *buf, int len); int BIO_gets(BIO *b,c

OpenCV图像处理篇之阈值操作函数

阈值操作类型 这5种阈值操作类型保留opencv tutorials中的英文名称,依次为: Threshold Binary:即二值化,将大于阈值的灰度值设为最大灰度值,小于阈值的值设为0. Threshold Binary, Inverted:将大于阈值的灰度值设为0,大于阈值的值设为最大灰度值. Truncate:将大于阈值的灰度值设为阈值,小于阈值的值保持不变. Threshold to Zero:将小于阈值的灰度值设为0,大于阈值的值保持不变. Threshold to Zero, In

直接在安装了redis的Linux机器上操作redis数据存储类型--对Sorted-Sets操作

一.概述: Sorted-Sets和Sets类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中.它们之间的主要差别是Sorted-Sets中的每一个成员都会有一个分数(score)与之关联,Redis正是通过分数来为集合中的成员进行从小到大的排序.然而需要额外指出的是,尽管Sorted-Sets中的成员必须是唯一的,但是分数(score)却是可以重复的. 在Sorted-Set中添加.删除或更新一个成员都是非常快速的操作,其时间复杂度为集合中成员数量的对数.由于Sorted