3.4列表类型

3.4.1介绍

列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者

获得列表的某一片段.

优点:内部使用的是双向链表,所以向列表两端添加元素的时间复杂度为O(1),获取

越接近两端的元素速度越快.

  • 双向链表也叫双链表,是链表的一种,它的每个数据结点中都有两个指针,分别

    指向直接后继和直接前驱
  • 时间复杂度是同一问题可用不同算法解决,而一个算法的质量优劣将影响到算法

    乃至程序的效率。O(1)为常数阶.

缺点:通过索引访问元素比较慢

所以列表适合的应用于:

1. 社交网站的新鲜事

2. 记录日志

  • 和散列类型键相同,最多能容纳232-1个元素

3.4.2命令

  1. 向列表两端增加元素

    lpush key value [value...]

    向列表左边增加元素

    rpush key value [value...]

    向列表右边增加元素
  2. 从列表两端弹出元素

    lpop key

    将列表左边的元素从列表中移除,并返回移除的元素值

    rpop key

    将列表左边的元素从列表中移除,并返回移除的元素值
  3. 获取列表中的元素个数

    llen key

    • 当键不存在时会返回0
  4. 获取列表片段

    lrange key start stop

    • redis获取列表片段方法:

      1. 所以从0开始,也支持负索引,表示从右边开始计算序数
      2. start的索引位置比stop的索引位置靠后,返回空列表
      3. 如果stop大于实际索引范围,则会返回到列表最右边的元素
      4. 片段包含stop元素(该处和python不同)
  5. 删除列表中指定的值

    lrem key count value

    删除列表中前count个值为value的元素,返回值是实际删除的元素个数.

    • count>0,lrem命令从左边开始删除

      count<0,lrem命令从右边开始删除

      count=0,lrem删除所有值为value的元素
127.0.0.1:6379> lpush num 0 1 2 3
4
127.0.0.1:6379> rpush num -4 -5 -6
7
127.0.0.1:6379> lpop num
3
127.0.0.1:6379> rpop num
-6
127.0.0.1:6379> llen num
5
127.0.0.1:6379> lrange num 0 -1
2
1
0
-4
-5
127.0.0.1:6379> lpush num -4 2 0
8
127.0.0.1:6379> lrange num 0 -1
0
2
-4
2
1
0
-4
-5
127.0.0.1:6379> lrem num 1 2
1
127.0.0.1:6379> lrem num -1 5
0
127.0.0.1:6379> lrem num 0 -4
2
127.0.0.1:6379> lrange num 0 -1
0
2
1
0
-5

3.4.3实践

  1. 存储文章ID列表

    我们使用列表型键posts:list记录文章ID列表.当发布新文章使用lpush命令

    把新文章的ID加入到这个列表中,删除文章时也要把列表中文章ID删除

    有了文章ID,可以使用lrange实现文章的分页,伪代码:
    $postsPerPage = 10
    $start = ($currentPage-1) * $postsPerPage
    $end = $currentPage * $postsPerPage -1
    $postsID = lrange posts:list,$start,$end
    # 获得了此页需要显示的文章ID,我们通过循环的方式读取文章
    for each $id in $postsID:
    $post = hgetall post:$id
    print 文章标题: $post.title

    该方法缺陷:

    1. 文章的发布时间不易修改

    2. 当文章数量较多时访问中间的页面性能较差

  2. 存储评论列表

    使用列表型键post:文章ID:comments来存储某个文章的所有评论,伪代码:
    # 将评论序列化字符串
    $serializedComment = serialize($author,$email,$time,$content)
    lpush post:42:comments,$serializedComment

3.4.4命令拾遗

  1. 获得/设置指定索引的元素值

    lindex key index

    lset key index value
    127.0.0.1:6379> rpush 诗人 李白 杜甫 白居易
    3
    127.0.0.1:6379> lindex 诗人 2
    白居易
    127.0.0.1:6379> lset 诗人 2 王维
    OK
    127.0.0.1:6379> lrange 诗人 0 -1
    李白
    杜甫
    王维
  2. 只保留列表指定片段

    ltrim key start end
    127.0.0.1:6379> ltrim 诗人 0 1
    OK
    127.0.0.1:6379> lrange 诗人 0 -1
    李白
    杜甫
    • 可应用于日志,只保留最近100条
  3. 向列表中插入元素

    linsert key befor pivot value

    向pivot前追加元素,返回值为列表长度

    linsert key after pivot value

    向pivot后追加元素,返回值为列表长度
    127.0.0.1:6379> linsert 诗人 before 李白 曹操
    3
    127.0.0.1:6379> linsert 诗人 after 杜甫 杜牧
    4
    127.0.0.1:6379> lrange 诗人 0 -1
    曹操
    李白
    杜甫
    杜牧
  4. 将元素从一个表转到另一个表

    rpoplpush source destination

    • 先执行rpop再执行lpush

Redis自学笔记:3.4入门-列表类型的更多相关文章

  1. Redis自学笔记:3.5入门-集合类型

    3.5集合类型 3.5.1介绍 在集合中的每个元素都是不同的,且没有顺序 表3-4集合类型和列表类型的对比 - 集合类型 列表类型 存储内容 至多232-1个字符串 至多232-1个字符串 有序性 否 ...

  2. Redis自学笔记:3.2入门-字符串类型

    3.2字符串类型 实际上redis不只是数据库,更多的公司和团队将redis用作缓存和 队列系统 3.2.1介绍 字符串类型是redis最基本的数据类型,它能存储任何形式的字符串, 包括二进制数据.你 ...

  3. Redis自学笔记:3.6入门-有序集合类型

    3.6有序集合类型 3.6.1介绍 在集合类型基础上,为集合中每个元素都关联了一个分数,故可以获得 分数最高(最低)的前N个元素,可以获得指定范围内的元素等 有序集合中每个元素不同,但它们的分数却可以 ...

  4. Redis自学笔记:3.3入门-散列类型

    3.3散列类型 3.3.1介绍 散列类型不能嵌套其他数据类型,一个散列类型可以包含至多232-1个字段 散列类型适合存储对象:使用对象类别和ID构成键名,使用字段表示对象的数据, 而字段值则存储属性值 ...

  5. Redis自学笔记:3.1入门-热身

    第3章:入门 3.1热身 获取符合规则的键名列表:keys 匹配key 表3-1 glob风格通配符规则 符号 含义 ? 匹配一个字符 * 匹配任意个(包括0个)字符 [ ] 匹配括号间的任一字符,可 ...

  6. JavaScript高级程序设计之自学笔记(一)————Array类型

    以下为自学笔记. 一.Array类型 创建数组的基本方式有两种: 1.1第一种是使用Array构造函数(可省略new操作符). 1.2第二种是使用数组字面量表示法. 二.数组的访问 2.1访问方法 在 ...

  7. jQuery:自学笔记(1)——基础入门

    jQuery:自学笔记(1)——基础入门 认识JQuery 1.jQuery概述 jQuery是一个快速.小巧 .功能丰富的JavaScript函数库.它可以实现“写的少,做的多”的目标. jQuer ...

  8. Redis自学笔记:1.简介

    博主教材:李子骅.人民邮电出版社.<redis入门指南> 博主操作系统系统:虚拟机Ubuntu16.04 博主redis版本:3.0.6 第1章:简介 redis是一个开源的.高性能的.基 ...

  9. Redis自学笔记:4.4进阶-消息通知

    4.4消息通知 4.4.1任务队列 传递任务的队列.与任务队列进行交互的实体有两类,一类是生产者,一类是消费者. 生产者将需要处理的任务放入任务队列中,二消费者不断从任务队列中读入任务 信息并执行. ...

随机推荐

  1. 【python】kafka在与celery和gevent连用时遇到的问题

    前提:kafka有同步,多线程,gevent异步和rdkafka异步四种模式.但是在与celery和gevent连用的时候,有的模式会出错. 下面是我代码运行的结果. 结论:使用多线程方式! 使用同步 ...

  2. MYSQL安装报错 -- 出现Failed to find valid data directory.

    运行环境:windows10数据库版本:mysql.8.0.12安装方式:rpm包直接安装 问题描述:mysql初始化的时候找不到对应的数据库存储目录 报错代码: 2018-10-13T03:29:2 ...

  3. laravel Blade 模板引擎

    与视图文件紧密关联的就是模板代码,我们在视图文件中通过模板代码和 HTML 代码结合实现视图的渲染.和很多其他后端语言不同,PHP 本身就可以当做模板语言来使用,但是这种方式有很多缺点,比如安全上的隐 ...

  4. vue指令

    <!DOCTYPE html><html><head> <meta charset="utf-8"> <title>指令 ...

  5. jmeter从CSV中获取非正常string

    jmeter从CSV中获取非正常string,如CSV中有一列值为{"firstname":"Jade"},那么在beanshell中如何获取并解析? 一般的用 ...

  6. 阿里云使用js 实现OSS图片上传、获取OSS图片列表、获取图片外网访问地址(读写权限私有、读写权限公共);

    详情请参考:https://help.aliyun.com/document_detail/32069.html?spm=a2c4g.11186623.6.763.ZgC59a 或者https://h ...

  7. 用ffmpeg把视频编码格式转为h.264

    command: ffmpeg -i infile.mp4 -an -vcodec libx264 -crf 23 outfile.h264

  8. mybatis + oracle insert clob,出现ORA-01461:仅能绑定要插入LONG列的LONG值

    在网上查了很久,有可能问题是出现在当从dual中取数据时,会将clob对象的字段转为Long型 最后的解决方法用到了Begin和end语法: 1.用到begin 和end 2.用到insert int ...

  9. Android Studio 修改包名最便捷做法

    Android Studio,咱们开发安卓的利器,自推出就受到移动开发者的追捧,但一路走来,大家谈到他,充满了兴奋之情之余,也略显羞涩.随版本自推出以来,不断完善BUG,但咱们还是深深地踩了进去,说多 ...

  10. Oracle数据重复,只取一条

    --方法一 select * from tb_supply where rowid=any(select max(rowid) from tb_supply group by phone_id) -- ...