• redis的 list


    redis的list是一个双向链表,既可以用作,也可以用作队列,幸好大学学过数据结构,还有印象。

    栈:先进后出,队列:先进先出

    redis链表操作:

    应用场景学习list链表:要获取最新的10个登录用户信息, 如果用sql的话:select * from user order by logintime desc limit 10; 但是数据量大的话,这一条sql下去,这个表全部的数据都要收到影响,对数据库的负载比较高,必要情况还需要给关键字段(id或者logintime)设置索引,过多设置索引也是比较耗费系统资源的。

    现在用redis的list来实现:只在list中保留5个数据,每次添加一个新的数据就删除一个旧的数据。每次都可以从链表中直接获取到需要的数据,极大的节省了各方面的资源。

    1,启动redis的操作终端,切换到第二个数据库,该数据库为空:

    ,

    2,lpush操作:执行命令lpush(l就是left的简写)命令向链表中添加5条数据,链表命名为 newlogin,表示新登录的用户,可以用type newlogin来查看newlogin的类型。

    现在redis的第二个数据库里就有一个key 是 newlogin 的链表,里边依次保存了xiaoming、jack、jim、zhangsan、lisi 五条数据。

     3,rpop操作:现在要再添加一条新数据,就从链表尾部删除一条数据,添加一个xiaoli,同时执行rpop(r是right的简写)从尾部删除第一个添加进去的数据(xiaoming):

    4,llen、lrange操作:llen newlogin返回list的长度。lrange newlogin 0 4返回list对应范围的元素,如果最大下标超过了list的长度,也是返回所有的元素。 

    rpush是从尾部添加一个元素,lpop是从头部删除一个元素,rpush和lpop配合使用;lpush和rpop配合使用。

    5,ltrim操作:截取list中的一部分元素:

  • 相关阅读:
    用户自定义异常
    触发异常
    第一阶段冲刺终
    第一阶段冲刺七
    第一阶段冲刺六
    第一阶段冲刺五
    第一阶段冲刺四
    Sufficient Statistic (充分统计量)
    DAG-GNN: DAG Structure Learning with Graph Neural Networks
    Masked Gradient-Based Causal Structure Learning
  • 原文地址:https://www.cnblogs.com/lihaoyang/p/6043380.html
Copyright © 2020-2023  润新知